基于极大极小分析法的井字棋对弈

基于极大极小分析法的井字棋对弈

ID:39474569

大小:775.50 KB

页数:12页

时间:2019-07-04

基于极大极小分析法的井字棋对弈_第1页
基于极大极小分析法的井字棋对弈_第2页
基于极大极小分析法的井字棋对弈_第3页
基于极大极小分析法的井字棋对弈_第4页
基于极大极小分析法的井字棋对弈_第5页
资源描述:

《基于极大极小分析法的井字棋对弈》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、基于极大极小分析法的井字棋对弈任务分析:首先,我们要知道,“井字棋”游戏(又叫“三子棋”),是一款十分经典的益智 小游戏,想必很多玩家都有玩过。“井字棋”的棋盘很简单,是一个3×3的格子,很像中国文字中的“井”字,所以得名“井字棋”。“井字棋”游戏的规则与“五子棋”十分类似,“五子棋”的规则是一方首先五子连成一线就胜利;“井字棋”是一方首先三子连成一线就胜利。游戏时一方是电脑,另一方是玩家。所以,这类游戏在开始时有两种方式:一种是玩家先走;另一种是电脑先走。这是我们要考虑的第一个问题。其次,由于与玩家对

2、战的是计算机,所以我们要编写一个过程,它可以使程序模拟人的思维与人下棋(其实就是“人工智能”的体现),这个过程也是本游戏的关键。此外,我们还要编写两个过程,其一用来时刻判断棋盘中是否有三个棋子连成一线;其二用来判断如果有三个棋子连成一线,是哪一方连成一线的,即判断哪一方获胜。如图所示为井字棋的一个格局,而格局之间的关系是由比赛规则决定的.通常,这个关系不是线性的,因为从一个棋盘格局可以派生出几个格局.例如图左侧所示的格局可以派生出5歌格局.例如图右侧所示,而从每一个新的格局又可派生出4个可能出现的格局.

3、因此,若将从对弈开始到结束的过程中所有可能出现的格局都画在一张图上,则可以得到一颗倒长的”树”.图1对弈问题中格局之间的关系设计思路设有九个空格,由MAX,MIN二人对弈,轮到谁走棋谁就往空格上放一只自己的棋子,谁先使自己的棋子构成“三子成一线”(同一行或列或对角线全是某人的棋子),谁就取得了胜利。用叉号表示MAX,用圆圈代表MIN。为了不致于生成太大的博弈树,假设每次仅扩展两层。估价函数定义如下:设棋局为P,估价函数为e(P)。(1)若P对任何一方来说都不是获胜的位置,则e(P)=e(那些仍为MAX空

4、着的完全的行、列或对角线的总数)-e(那些仍为MIN空着的完全的行、列或对角线的总数。(2)若P是MAX必胜的棋局,则e(P)=+∞。 (3)若P是B必胜的棋局,则e(P)=-∞。要注意利用棋盘位置的对称性,在生成后继节点的位置时,下列博弈结局都是相同的棋局(在博弈中,一宇棋的分枝系数比较小起初是由于对称性,而后是由于棋盘上未布子的空格减少所致)。 现在我们假设MAX走了这一步,而MIN的回步是直接在X上方的空格里放上一个圆圈(对MAX来说这是一步坏棋,他一定没有采用好的搜索策略)。下一步,MAX又在新

5、的格局下搜索两层. 现在图中MAX有两个可能“最好的”优先走步,假设MAX走了图上指明的那一步。而MIN为了避免立即败北被迫走了另一步,从而产生如下棋局:MAX再次搜索. 在这棵树中某些端节点(例如其中一个标记着A)代表MIN获胜,因此它们的估值为—∞。当这些估值被倒推回去时,可看到MAX的最好的也是唯一能使他避免立即失败的一个走步。现在,MIN可以看出MAX必然在他的下一走步中获胜,因此,MIN只好认输。流程图设计步骤(1)选定博弈算法;(2)建立一个简单的应用程序(如字符界面程序)来测试算法;(3)

6、选定图形界面中要实现的其他功能;(4)实现图形界面的井字棋程序。算法测试程序功能的函数:(1)可能胜利的方法:structCHESS_MAN(2)显示棋盘边框:voiddisp_chess_board(void)(3)打印棋盘函数:voidinit_chess_board(void)(4)用户输入落子位置函数:intenter_chess_man(5)判断函数:intchk_winner(intplayer)(6)评估函数值计算函数:intget_best_chess(判断哪一方获胜包含在5和6中)总程

7、序:#include"stdio.h"#include"malloc.h"#defineSIZE3#ifndefFALSE#defineFALSE0#endif#ifndefTRUE#defineTRUE1#endif#defineNONE0#definePLAYER_A1#definePLAYER_B2#defineWARNNING255#defineCOMPETITOR200#defineWINNER-1charchessboard[SIZE][SIZE];structCHESS_MAN{intro

8、w;intcol;};/*PLAYER可能胜利的方法*/intget_value(intplayer){inti,j,ret=0;introw,col,inc;intbNONE=FALSE;/*检查所有行*/for(i=0;i

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。