新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论高级C/C++编程、代码重构(Refactoring)、极限编程(XP)、泛型编程等话题
    [返回] 计算机科学论坛计算机技术与应用『 C/C++编程思想 』 → [原创][推荐] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 4009 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [原创][推荐] 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     红心宝贝 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:1
      积分:54
      门派:XML.ORG.CN
      注册:2006/10/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给红心宝贝发送一个短消息 把红心宝贝加入好友 查看红心宝贝的个人资料 搜索红心宝贝在『 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、双四和多于五子的连棋)。因为在平时我下的五子棋是没有这些
    禁手的。


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/10/6 12:34:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 C/C++编程思想 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/11/23 0:05:45

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.012ms