微机原理课程设计——五子棋

上传人:wt****50 文档编号:35776261 上传时间:2018-03-20 格式:DOC 页数:3 大小:25.50KB
返回 下载 相关 举报
微机原理课程设计——五子棋_第1页
第1页 / 共3页
微机原理课程设计——五子棋_第2页
第2页 / 共3页
微机原理课程设计——五子棋_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《微机原理课程设计——五子棋》由会员分享,可在线阅读,更多相关《微机原理课程设计——五子棋(3页珍藏版)》请在金锄头文库上搜索。

1、电脑下子实际上是分两个步骤的,第一个步骤是尽可能的收集棋盘格局的信息,并且使这些信息以一定的格式存放再内存中,以便于第二步的处理。第二个步骤就是,对收集到的信息进行分析处理,即要给出一个规则,用穷举搜索的办法遍历所有收集到的信息,搜索的过程实际上是用所定下的规则去衡量每一点的权值,搜索的目的是为了找到一个权值最大的点,这个点就是当前的最优解,也就是应该下的子。 具体的说来,在第一步中,可以用一个 1313 的二维数组来存放棋盘上每一个点的信息。每下一步棋,就用一个 1313 的二重循环去遍历棋盘上的每一个点,可以参照如下的方法,即对于每一个点,我们假定这个点放上黑子,这时候就判断这个黑子放上去

2、后,会形成多少个活 2、活 3、活 4 和五,然后把对应的数值填入上面所说的二维数组里面,然后再假定这个点放白棋,又会形成多少个活 2、活 3、活 4 和五,也填入二维数组里面。当然你也可以用两个二维数组分别存储黑子和白子的情况,而且最好采用结构体数组。这样遍历完棋盘后,再数组里面就保存了有用的棋盘格局信息。如下:typedef struct tagNodeInfoint numof2;int numof3;int numof4;int numof5;NodeInfo,*PNodeInfo;NodeInfo WHITE_CHESS1313;NodeInfo BLACK_CHESS1313;下面

3、就是如何利用所得到的信息去下棋了。这个过程也是遍历分析所得的信息的过程。对上面的信息,我们可以很好的处理。比如,假定四三是必胜的,则我们给他的权值就很大比如 100 吧,而活二给的权值应该比较小,就给 1 吧。然后你可以得到一个权值的计算公式,比如权值活二的个数1+活三的个数5+活四的个数10+四三的个数100就是类似这样的公式,当然我上面是随便举的。下棋是就是遍历每一个点的信息,对每一个点计算权值,找到权值最大的就是要下的点了。上面说了用两个数组分别保存黑子和白子的信息也是有必要的,因为可以计算出某一点对黑白双方的重要程度。就是说如果轮到你下白子了,你光看哪一点对白子有利也不行呀,还要看那些点对黑子有利,并且要比较这种有利的程度。如果你放某一点能成活 3,而别人放另一点就是四三了,你就要抢先吧那一点占了。当然这样的算法也仅仅是考虑了当前的最优解,如果要进一步提高人工智能,就要用更高级的搜索法,对未来的几步进行搜索了。一般都是将搜索空间组织成二叉树的结构。这个我学的也不是很好,所以就不讲了。实际上,上面讲的办法还具有一般意义,不光是可以用到五子棋,再其他的棋类里面也是这样的,先搜索信息,再分析。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号