Loading
新闻中心库存中心价格中心PDF中心图片中心
ICGLE 电子技术支持中心,为电气人员和相关企业提供全面的信息(IC技术\IC库存\IC图片\PDF资料等)服务
总线设计PCB设计单片机DSPARM
JAVA驱动设计C/C++汇编J2EE网络协议中间件技术嵌入式系统无线通信通信网络模拟技术接口电路显示光电传感与控制EDA/PLD
气流体控制电子产品电机及工具通信设备仪器仪表电线电缆建筑电气低压电器高压电器电源工控自动化广电设备医疗器械More..
电源设计仪器仪表技术专递电路图片电子专栏储存技术汽车电子测量测试音响技术家用电器
成功方案市场分析行业标准应用前沿芯片应用综合专区
五子棋算法
来源:普博C/C++语言世界   作者:佚名
字体大小:[大][中][小]


  任何一种棋类游戏其关键是对当前棋局是否有正确的评分,评分越准确则电脑的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<=F1<L2<=F2<=L1<F1<L2<F2<L3<=F3<L4<F4=F4

  从这个关系包含了进攻和防守的关系(当然,这个关系是由我定的,你可以自己定义这些关系)。对这些关系再进一步细化,如在一个可下棋的点,其四个方向上都有活三,也比不上一个冲四,所以我们可以又得到4*F3<L4这个关系,同样,我们还可以得到其它的关系,如:4*F2<L3、4*L3<F3...,这些的关系由于你的定法和我的定法制可能不一样,这样计算机的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、双四和多于五子的连棋)。因为在平时我下的五子棋是没有这些禁手的。
Upload by 小刘(2007-6-1)
IC
IC
推荐技术文章:
·设计彩色框的C源程序..
·关于二十四点游戏的编程思路与基本算法..
·图形模式下的汉字显示..
·文件加密技术一例..
·用c语言实现艺术清屏..
·用C语言进行CGI程序设计..
·两个矩阵相乘的源程序..
·精细绘图及动画..
·图形旋转的C语言源程序..
·字符串查找..
·C和C++ 字符串字面量的比较..
·Linux下的多线程编程..
·基于C语言的设计流优化语音识别芯片结....
·针对嵌入式SoC应用的C编程优化..
·如何用C语言开发DSP嵌入式系统..
·浅析malloc()的几种实现方式..
·用Eclipse+MyEclipse....
·Java中使用接口实现多继承和多态的....
·提升JSP中页面响应速度的七大秘籍绝....
·Static和Final修饰类属性变....
·探讨JAR文件无限可能性
·Tomcat集群与负载均衡
·使用Java NIO提高服务端程序的..
·java虚拟机管理大内存
·java中使用MD5加密算法进行加密
·EMF模型解析的策略分析
·编写对GC友好,又不泄漏的代码
·J2SE5.0新特性之windows..
·java中通过xpath处理含有命名..
·使用Hashtable对字符串进行碰..
·揭开 Java 安全标准的神秘面纱
·java的线程安全四种方式五个等级
·破除java神话之原子操作都是线程安..
·Java服务器端编程安全必读
·编写高效的线程安全类
·用Java向Web站点发送POST请..
·Java多线程的优先级
·基于Java的嵌入式网络视频服务器
·Java源码分析:深入探讨Itera..
·在Java里面调用CUI程序的方法
IC
IC

©2007 版权归ICGLE所有   页面执行时间:46.875毫秒