VC实现五子棋游戏的一个算法示例
本文讲述了VC实现五子棋游戏的一个算法示例,该算法采用极大极小剪枝博弈算法,感兴趣的读者可以对程序中不完善的部分进行修改与完善。
该设计主要包括:数据结构、估值函数、胜负判断、搜索算法
程序运行界面如下:
具体实现步骤如下:
1、数据结构
//记录每步棋,可以建立链表用来进行悔棋、后退(本程序没有实现) struct Step { int x,y; //棋子坐标 int ball; //表示下子方{BLACK,WHITE} }; //记录棋盘情况,用于搜索过程 class CBoardSituation { public: int nArrBoard[15][15]; //棋盘情况 struct Step machineStep; //AI所下的那一步 long value; //盘面所打的分数 }; //当前棋盘,用于棋盘显示 int nArrBoard[15][15];
2、估值函数
分析当前棋盘上黑白双方棋型:五连、活四、冲四、双活三、单活三、眠三、活二、眠二,然后根据五子棋规则给棋盘打分,
具体分值可以根据经验自己确定。本程序中:五连=9999(极值),活四=9990,冲四=9980,双活三=9970,多活三加2000,
单活三加200,每个眠三加10,每个活二加4,每个眠二加1。其中打分时还要根据当前下棋方情况进行打分。
3、胜负判断
这个比较简单,根据最后落子情况从水平、垂直、左斜、右斜四个方向检查是否存在五个连续棋子即可。
4、搜索算法
算法采用极大极小值博弈算法,它的主要思想为:预测后N步下棋情况,对预测的后N个棋盘进行打分。轮到自己下棋时选分值最大的,轮到对方下时选分值最小的。选出我们认为最优的作为下一步走法。本程序算法基本思想如下(算法语言表示):
void DFAI() { long value=-MAXINT; //对初始根节点的value赋值 CBoardSituation currentBoard; //获取当前机器新棋面情况 for(int i=0;i<15;i++) for(int j=0;j<15;j++) currentBoard.nArrBoard[i][j]=nArrBoard[i][j]; currentBoard.machineStep.ball=ComputerBall; currentBoard.machineStep.x=gnRow; currentBoard.machineStep.y=gnColumn; currentBoard.value=Eveluate(currentBoard.nArrBoard,BLACK); //选取几个最好的下法(贪婪法)-->CountList; GetSeveralGoodPlace(¤tBoard,WHITE); CountList.RemoveAll(); POSITION pos=templist.GetHeadPosition(); for(int j=0;j { CountList.AddTail(templist.GetNext(pos)); } pos=CountList.GetHeadPosition(); CBoardSituation *pBoard; //对这些盘面做进一步深度搜索 for(i=0;i { pBoard= &(CountList.GetNext(pos)); pBoard->value=Search(pBoard,BLACK,value,0); value=Select(value,pBoard->value,WHITE); //找出最大的分值 } //回到链表头 pos=CountList.GetHeadPosition(); for(i=0;i { pBoard= &(CountList.GetNext(pos)); if (value==pBoard->value) //找出得到最高分的盘面 { value=pBoard->value; gnRow=pBoard->machineStep.x; gnColumn=pBoard->machineStep.y; bPlayerDo=TRUE; //当前下子方改为人 break; } } //其他处理 } 其中Search()函数如下: //算法搜索函数 long Search(CBoardSituation *board,int mode,long &oldvalue, int depth) { CList m_DeepList; long value; if(depthnArrBoard,mode))<8000) { value=(mode==WHITE)?-MAXINT:MAXINT; //选择几个最好的搜索目标 GetSeveralGoodPlace(board,mode); POSITION pos=templist.GetHeadPosition(); for(int j=0;j { m_DeepList.AddTail(templist.GetNext(pos)); } pos=m_DeepList.GetHeadPosition(); CBoardSituation successorBoard; for(int i=0;i { successorBoard= m_DeepList.GetNext(pos); //是否进行继续深度搜索(剪枝):极大极小值法 if((mode==WHITE && value<=oldvalue) || (mode==BLACK && value>=oldvalue)) { if(mode==WHITE) value=Select(value,Search(&successorBoard,BLACK,value,depth+1),WHITE); else//mode==BLACK value=Select(value,Search(&successorBoard,WHITE,value,depth+1),BLACK); } } return value; } else//搜索结束条件 { return Eveluate(board->nArrBoard,mode);//棋面打分 } return 0; }
相关文章
- 作者:Sabine 【导读】本文介绍了C#的四种排序算法:冒泡排序、选择排序、插入排序和希尔排序 冒泡排序 using System; namespace BubbleSorter { public class Bubb...2020-06-25
- 这篇文章主要用实例讲解C#递归算法的概念以及用法,文中代码非常详细,帮助大家更好的参考和学习,感兴趣的朋友可以了解下...2020-06-25
- 这篇文章主要介绍了SpringMVC文件上传原理及实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-07-15
- 这篇文章主要是介绍了.net C# 实现任意List的全组合算法实现代码,需要的朋友可以参考下...2020-06-25
图文详解Heap Sort堆排序算法及JavaScript的代码实现
这篇文章以图文详解Heap Sort堆排序算法及JavaScript的代码实现,堆排序算法基于类二叉树的堆数据结构,需要的朋友可以参考下...2016-05-05C# MVC模式中应该怎样区分应用程序逻辑(Controller层)和业务逻辑(Model层)?
这篇文章主要介绍了C# MVC模式中应该怎样区分应用程序逻辑(Controller层)和业务逻辑(Model层)?,这也小编做.NET项目时经常思考和让人混乱的一个问题,这篇文章写的挺好,一下清晰了许多,需要的朋友可以参考下...2020-06-25同时兼容JS和C#的RSA加密解密算法详解(对web提交的数据加密传输)
这篇文章主要给大家介绍了关于同时兼容JS和C#的RSA加密解密算法,通过该算法可以对web提交的数据进行加密传输,文中通过图文及示例代码介绍的非常详细,需要的朋友们可以参考借鉴,下面来一起看看吧。...2020-06-25- 这篇文章主要给大家分享的是pygame游戏进行声音添加的方法,这文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!...2021-10-23
- 这篇文章主要介绍了JavaScript 实现生命游戏的示例步骤,帮助大家更好的理解和学习使用JavaScript,感兴趣的朋友可以了解下...2021-04-24
使用Maven 搭建 Spring MVC 本地部署Tomcat的详细教程
这篇文章主要介绍了使用Maven 搭建 Spring MVC 本地部署Tomcat,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-08-16- 这篇文章主要介绍了JS实现的随机排序功能算法,结合具体实例形式分析了javascript常用的排序算法实现技巧,需要的朋友可以参考下...2017-06-15
- 这篇文章主要介绍了C#常用数据结构和算法,这里我们总结了一些知识点,可以帮助大家理解这些概念。...2020-06-25
- 这篇文章主要为大家详细介绍了C#拼图游戏的编写代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-06-25
- 今天小编跟大家分享13个有趣又好玩的Python小游戏示例代码,教你如何通过边打游戏边学编程!感兴趣的小伙伴快跟随小编一起学习起来...2022-02-23
- 这篇文章主要介绍了SpringMvc自动装箱及GET请求参数原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-19
vc提示unexpected end of file found的原因分析
这篇文章主要介绍了vc提示unexpected end of file found的原因分析,给出了几点常见错误原因的分析,需要的朋友可以参考下...2020-04-25- 这篇文章主要介绍了SpringMvc获取请求头请求体消息过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-17
- 这篇文章主要介绍了CocosCreator MVC架构,同学们在制作游戏过程中,尽量使用一些架构,会避免很多问题...2021-04-16
基于Python-Pycharm实现的猴子摘桃小游戏(源代码)
这篇文章主要介绍了基于Python-Pycharm实现的猴子摘桃小游戏,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-02-20- 这篇文章主要介绍了python基于tkinter制作图形界面的2048游戏的方法,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下...2021-04-06