
- 本栏最新文章
- 游戏制作:猜数字算法(as2.0) 07-03
- ActionScript 3.0垃圾回收 07-03
- 左侧菜单导航栏的制作 07-02
- FLASH中一些不太常见的代码写法 07-02
- 造成Flash动画文件增大原因与解决的方法 06-27
- xml中运用后代存取运算符(..)的问题 06-25
- swf图片加载失败问题 06-25
- PHP+MYSQL+Flash做留言本 06-25
- flash如何适应任何分辨率方法大集合 06-24
- 用FLASH里的按钮控制网页中层的显示隐藏 06-24

- 本栏推荐文章
- Photoshop教程:水灵灵的美女调出来 12-30
- AS3与后台交互 12-21
- AS3通俗教程---AS3自身loading制作 12-19
游戏制作:猜数字算法(as2.0)
猜数字是我初中时在课堂上最喜欢玩的游戏....游戏平台嘛.....我的文曲星PC260........
这个游戏的规则比较简单,一般两个人玩,一方出数字,一方猜。出数字的人要想好一个没有重复数字的4位数,不能让猜得人知道。猜的人就可以开始猜。 每猜一个数字,出数者就要根据这个数字给出几A几B,其中A前面的数字表示位置正确的数的个数,而B前的数字表示数字正确而位置不对的数的个数。
如正确答案为5234,而猜的人猜5346,则是1A2B,其中有一个5的位置对了,记为1A,而3和4这两个数字对了,而位置没对,因此记为2B,合起来就是1A2B。
接着猜的人再根据出题者的几A几B继续猜,直到猜中为止。
次数限制
有的时候,这个游戏有猜测次数上的限制。根据计算机测算,这个游戏,如果以最严谨的计算,任何数字可以在7次之内猜出。而有些地方把次数限制为6次或更 少,则会导致有些数可能猜不出来。而有些地方考虑到人的逻辑思维难以达到计算机的那么严谨,故设置为8次甚至10次。也有的没有次数上的限制。
首先我们先来完成对游戏的实现,反过来再为游戏完成算法反猜...[游戏预览]
游戏的实现必没有什么难度,只是一些简单的算法而已,首先生成一个各不相同的四位数,可以向用一个项为0~9的数组,然后每次从数组里随机取出一个数字并删除该位置的数字,这样便可以保证四位数在各个位上互不相同..代码实现为:
function getRandomNum()//生成四位不相同數字
{
var strArray = new Array(0,1,2,3,4,5,6,7,8,9);
var s="";
for(var i=0;i<4;i++)
{
s += strArray.splice(parseInt(strArray.length *Math.random()),1)
}
return s;
}
function chkSameNum(s)//檢查數字中是否有相同數字
{
for(var i=0;i<s.length;i++)
{
for(var j=i+1;j<s.length;j++)
{
if(s.substr(i,1) == s.substr(j,1))
{
return true;
}
}
}
return false;
}
刚实现了计算机出题,让我们猜,那可以让我们出题,让计算机来猜吗?当然可以,而且也可以验证一下计算机是不是都能在七次以内完成数字的猜测..首先先看一下算法的演示.[点进预览]
算法的原理,还是使用网上较为普遍的枚举排除法,因为原理简单,所以也较容易理解与实现.
从0~9随便取出四位组成一个互不相同的四位数,按照组合的算法,一共有10*9*8*7=5040个.也就是无论你想的是哪一个数,一定是在这 5040个里面.所以我们每一步就必须枚举出这5040个可能组合,并存于一个数组中,我们称这个数组为字典,我们的答案就存在这个字典里面,每一次我们 都从字典里取出一个来猜测,并排除一切不符合判断结果的项,从字典里删除,一直排除到只剩一项的时候,就是我们的正确答案了.
我们可以先通过一个函数来检测这个四位数是否是各个位置上都不相同的.
var dictArray ;//当前可能枚举的数组
function chkSameNum(num)//检查数字中是否有相同的数字
{
num = parseInt(num,10);//保证如0123这样的数能够正确的被转化为10进制的数
var a=parseInt(num/1000)%10;
var b=parseInt(num/100)%10;
var c=parseInt(num/10)%10;
var d=parseInt(num)%10;
if(a==b || a==c || a==d || b==c || b==d || c==d) return true;
return false;
}
接着我们可以通过一个循环来存储整个初始枚举字典.
dictArray = new Array();
for(var i=123;i<=9876;i++)
{
if(!chkSameNum(i))
{
if(i<1000)dictArray.push("0"+i);
else dictArray.push(""+i);
}
}
对任何一个数的猜测,到底有多少种判断结果呢?我们先来罗列一下.
0A0B,0A1B,0A2B,0A3B,0A4B
1A0B,1A1B,1A2B,1A3B
2A0B,2A1B,2A2B
3A0B
4A0B
可以看到一共有十四种判断结果,注意,是不会有出现3A1B的情况的.我们可以将每一个判断用一个数字来表示.10位数表示A,个位数表示为B,则 任何一种判断可以表示为A*10+B .chkScore函数是对随意的两个四位数进行比较,并返回比较的判断结果,如两个数的判断结果为40,也即4A0B,所以两个数为相同的数.
{
var a=0,b=0;
for(var i=0;i<4;i++)
{
for(var j=0;j<4;j++)
{
if(guessnum.substr(j,1)==textnum.substr(i,1))
{
if(i==j)a++;
else b++;
}
}
}
return a*10+b;
}
{
if(chkScore(guessnum,dictArray[i])!=score)
dictArray.splice(i,1);
}
在枚举所有可能值与第一次猜测的时候,需要花费很长的时间(大概在10S左右)导致假死状态,也关无法响应,其实这并不是算法太慢的问题,而是下拉列表要显示太多的选项而拖慢了..


