C语言程序设计---五子棋 (1).docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
五子棋 算法:任何一种棋类游戏其关键是对当前棋局是否有正确的评分,评分越准确则电脑的AI越高。五子棋游戏也是如此,但在打分之前,我们先扫描 整个棋盘,把每个空位从八个方向上的棋型填入数组gStyle(2, 15, 15, 8, 2),其中第一个下标为1时表示黑棋,为2时表示白棋,第二和第三 个下标表示(x,y),第四个下标表示8个方向,最后一个下标为1时表示棋子数,为2时表示空格数,如: gStyle(1,2,2,1,1)=3表示与坐标(2,2)在第1个方向上相邻的黑棋棋子数为3 gstyle(1,2,2,1,2)=4表示与坐标(2,2)在第1个方向上的最近的空格数为4 在定义方向时,也应该注意一定的技巧,表示两个相反的方向的数应该差4,在程序中我是这样定义的: Const DIR_UP = 1 Const DIR_UPRIGHT = 2 Const DIR_RIGHT = 3 Const DIR_RIGHTDOWN = 4 Const DIR_DOWN = 5 Const DIR_DOWNLEFT = 6 Const DIR_LEFT = 7 Const DIR_LEFTUP = 8 这样我们前四个方向可以通过加四得到另一个方向的值。如果你还是不太明白,请看下面的图: --------- --------- ---oo---- -ox*xx--- --------- --------- 图中的*点从标为(4,4),(打*的位置是空位),则: gStyle(2,4,4,1,1)=1在(4,4)点相邻的上方白棋数为1 gStyle(2,4,4,1,2)=2在(4,4)点的上方距上方白棋最近的空格数为2 gStyle(1,4,4,3,1)=2在(4,4)点相邻的右方黑棋数为2 gStyle(1,4,4,3,2)=1在(4,4)点的右方距右方黑棋最近的空格数为3 ...   一旦把所有空点的棋型值填完,我们很容易地得出黑棋水平方向上点(4,4)的价值,由一个冲1(我把有界的棋称为冲)和活2(两边无界的 棋称为活)组成的。对于而白棋在垂直方向上点(4,4)的价值是一个活1,而在/方向也是活1所以,只要我们把该点的对于黑棋和白棋的价值算出 来,然后我们就取棋盘上各个空点的这两个值的和的最大一点作为下棋的点。然而,对各种棋型应该取什么值呢?我们可以先作如下假设:   Fn 表示先手n个棋子的活棋型,如:F4表示先手活四   Fn表示先手n个棋子的冲棋型,如:F4表示先手冲四   Ln 表示后手n个棋子的活棋型,如:L3表示后手活三   Ln表示后手n个棋子的冲棋型,如:L3表示后手冲三   .   .   .    根据在一行中的棋型分析,得到如下关系: L1=F1L2=F2=L1F1L2F2L3=F3L4F4=F4    从这个关系包含了进攻和防守的关系(当然,这个关系是由我定的,你可以自己定义这些关系)。对这些关系再进一步细化,如在一个可下 棋的点,其四个方向上都有活三,也比不上一个冲四,所以我们可以又得到4*F3L4这个关系,同样,我们还可以得到其它的关系,如:4*F2L3、4*L3F3...,这些的关系由于你的定法和我的定法制可能不一样,这样计算机的AI也就不一样,最后我们把分值最小的L1值定为1,则我们就得 到了下面各种棋型的分值,由C语言表示为: F[2][5]={{0,2,5,50,16000},{0,10,30,750,16000}}; L[2][5]={{0,1,5,50,3750},{0,10,30,150,4000}};    F数组表示先手,第一个下标为0时表示冲型,第二个下标表示棋子数,则F2对应F[0][2]L数组表示后手,第一个下标为0时表示冲型,第二 个下标表示棋子数,则L2对应F[1][2]Ok,棋型的分值关系确定好了以后,我们把每一个可下点的四个方向的棋型值相加(包括先手和后手的分 值),最后选择一个最大值,并把这一点作为计算机要下的点就OK了:)。 后话: 1、得到最大值也许不止一个点,但在我的程序中只选择第一个最大点,当然你可以用于个随机数来决定 选择那一个最大值点,也可以对这些最大值点再作进一步的分析。 2、在这个算法中我只考虑了周围有棋子的点,而其它点我没有考虑。 3、可以再更进一步,用这个算法来预测以后的几步棋,再选择预测值最好的一步,这样电脑的AI就更高了 4、这个算法没有考虑黑棋的禁手(双3、双四和多于五子的连棋)。因为在平时我下的五子棋是没有这些 禁手的。 ? /**********************************************************/ /* 本程序在Turbo C或Borland C

文档评论(0)

80092355km + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档