开发工具

Python版本:3.6.4

相关模块:

graphics模块。

环境搭建

安装Python并添加到环境变量即可。

注:

graphics模块在相关文件中已经提供,就是一个py文件,直接放在当前路径或者放到python安装文件夹下的site-packages文件夹内均可。

原理简介

对于五子棋这样的博弈类AI,很自然的想法就是让计算机把当前所有可能的情况都尝试一遍,找到最优的落子点。这里有两个问题:

(1)如何把所有可能的情况都尝试一遍;

(2)如何定量判断某落子点的优劣。

对于第一个问题,其实就是所谓的博弈树搜索,对于第二个问题,其实就是所谓的选择评估函数。评估函数的选取直接决定了AI算法的优劣,其形式也千变万化。可以说,每个评估函数就是一个选手,对不同的棋型每个选手自然有不同的看法和应对措施,当然他们的棋力也就因此各不相同了。

但博弈树搜索就比较固定了,其核心思想无非是让计算机考虑当前局势下之后N步所有可能的情况,其中奇数步(因为现在轮到AI下)要让AI方的得分最大,偶数步要让AI方的得分最小(因为对手也就是人类,也可以选择最优策略)。

当然这样的搜索其计算量是极大的,这时候就需要剪枝来减少计算量。例如下图:

其中A代表AI方,P代表人类方。AI方搜索最大值,人类方搜索最小值。因此Layer3的A1向下搜索的最终结果为4,Layer3的A2向下搜索,先搜索Layer4的P3,获得的分值为6,考虑到Layer2的P1向下搜索时取Layer3的A1和A2中的较小值,而Layer3的A2搜索完Layer4的P3时,其值就已经必大于Layer3的A1了,就没有搜索下去的必要了,因此Layer3到**Layer4的路径3就可以剪掉了**。

上述搜索策略其实质就是:

minimax算法+alpha-beta剪枝算法。

了解了上述原理之后,就可以自己写代码实现了。当然实际实现过程中,我做了一些简化,但万变不离其宗,其核心思想都是一样的。

具体实现过程详见相关文件中的源代码。

文章来源: blog.51cto.com,作者:他说Python,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.51cto.com/15010956/2555717

python五子棋ai棋力最高_Python实现AI五子棋相关推荐

  1. python自动抠头像图_Python实现AI自动抠图实例解析

    一.简介 抠图是用PS? 用魔棒和快速选择工具? 遇到复杂背景怎么办? 最近发现一个神奇的工具--Remove Image Background 它是基于Python.Ruby和深度学习技术开发,通过 ...

  2. python百度ai拼接身份证_Python 百度ai身份证接口案例

    调用百度Ai 完成一个学生信息录入的网页小案例 添加图片,身份证信息对号入座 utils.py #encoding:utf-8 import requests import urllib from u ...

  3. python五子棋ai棋力最高_棋力最强的五子棋 App 是什么?

    插嘴说下这个五子棋大师 编程我不懂,这个五子棋大师的计算尚可,应该在五步以上,除去掌握比较熟练的棋型,大部分情况下我没有它算的远,如果正常和它下的话,想赢最高级,很吃力. 但是我还是可以轻松虐它,因为 ...

  4. python简单网格五子棋_python实现简单五子棋游戏

    本文实例为大家分享了python实现简单五子棋游戏的具体代码,供大家参考,具体内容如下 from graphics import * from math import * import numpy a ...

  5. python五子棋算法_python实现简单五子棋游戏

    本文实例为大家分享了python实现简单五子棋游戏的具体代码,供大家参考,具体内容如下 from graphics import * from math import * import numpy a ...

  6. python写五子棋游戏下载_python实现简单五子棋游戏

    本文实例为大家分享了python实现简单五子棋游戏的具体代码,供大家参考,具体内容如下 from graphics import * from math import * import numpy a ...

  7. Scratch3.0——助力新进程序员理解程序(难度案例三、五子棋双人对战-电脑需要AI写不出来)

    Scratch3.0--助力新进程序员理解程序(难度案例三.五子棋双人对战-电脑需要AI写不出来) 前言 一般来说,针对6-18岁的少年儿童开展的编程教育,现在,最常见的形式是线上和线下模式相结合的课 ...

  8. java走棋_Java五子棋小游戏(控制台纯Ai算法)

    Java五子棋小游戏(控制台纯Ai算法) 继续之前的那个五子棋程序 修复了一些已知的小Bug 这里是之前的五子棋程序 原文链接 修复了一些算法缺陷 本次增加了AI算法 可以人机对战 也可以Ai对Ai看 ...

  9. Github 上火热的十个 Python 项目,从Debug工具到AI水军、量化交易系统。( 嗨学编程)

    Github 上火热的十个 Python 项目,从Debug工具到AI水军.量化交易系统. https://blog.csdn.net/fei347795790/article/details/101 ...

最新文章

  1. linux firefox xvfb,自动化测试之linux+xvfb+selenium+firefox+python测试环境搭建与测试
  2. cityhash 算法的使用
  3. 视频分享:编码与代码评审-质量与现实的最激烈冲突点(完整版)
  4. Java中Byte类型数据在运算中的问题
  5. android 手机跑分,安兔兔安卓手机跑分性能榜公布:第一名实至名归?
  6. HIT训练营----1 题解
  7. java学习(58):私有内部类后访问
  8. Hungary(匈牙利算法)——二分图最大匹配
  9. 玩,玩什么,怎么玩?
  10. 在C#代码中应用Log4Net(四)在Winform和Web中捕获全局异常
  11. apk与android系统签名
  12. 20155210 网络攻防技术 实验三 免杀原理与实践
  13. 信息搜集之常见的web组合
  14. Linux驱动开发必看
  15. 入门嵌入式HTML/CSS/脚本引擎 sciter
  16. c语言 多核优化,【模型工具】一种对SWMM5的多核优化
  17. 从本钢板B看低市盈率投资收益
  18. 手绘 | 我说话直,你别介意——我呸!
  19. 我和欧阳娜娜一起搞研发
  20. 数仓--拉链表实战⭐⭐⭐⭐⭐

热门文章

  1. Confluence 6 配置快速导航
  2. 用HOSTS文件屏蔽网站
  3. 选择排序、冒泡排序、插入排序、快速排序、希尔排序、归并排序、堆排序和希尔排序的java实现比较
  4. zoj 3587 Marlon's String(拓展KMP+dp)
  5. 常见的连续型随机变量分布
  6. 第三节 树莓派EC20之PPP拨号上网
  7. Echarts 图表生成渐变色方法
  8. 利用gdal给影像添加金字塔
  9. c语言编活期储蓄银行系统,C语言编程1活期存款。活期利息每一季度结算...
  10. 女人一生中重要的三件事。