基于Python实现的智能五子棋游戏设计与实现

智能五子棋游戏

设计要求

使用Python语言,结合博弈树启发式搜索alpha-beta剪枝技术,开发一个人机五子棋博弈游戏

具体要点

  1. 设计一个1515列棋盘,要求自行给出估价函数,按极大极小搜索方法,并采用α-β剪枝技术
  2. 采用人机对弈方式,对弈双方设置不同颜色的棋子,一方走完一步后,等待对方走步,对弈过程的每个棋局都在屏幕上显示出来;
  3. 当某一方在横、竖或斜方向上先有5个棋子连成一线时,该方为赢。

PS

能力有限😢,游戏以玩家执黑先下,且忽略禁手为前提进行设计。

更新记录

  • Version 0.5 :完成初版核心代码,游戏可以正常运行,满足结束游戏的判定*(即横、竖或斜方向上先有5个棋子连成一线)*时,游戏正常结束,但AI思考时间过长,平均时长80s。
  • Version 0.5 _improved
    1. 优化评估函数缩小搜索范围,使得AI更加智能,思考时间更短,平均时长1s;
    2. 优化游戏结束判断,使玩家和AI胜利输出不同文字
    3. AI难度下降,落子效果不佳。
  • Version 1.0
    1. 增加最大搜索深度AI智能程度显著提升,对弈难度提升;
    2. AI思考时间过长,为确保胜利落子速度慢;
  • Version 1.0_beta
    1. 修改权重,对威胁更大的棋子形式赋予更大权重
    2. 修改搜索深度,减少思考时间;
    3. 增加连续棋子情况的判断,从而判断棋形,使AI具有更优的落子选择;
    4. 修改评价函数,适应前面的更改;
    5. 从运行结果来看效果不佳,智能程度不如v1.0版本,落子选择不佳。
  • Version 1.5
    1. 基于v1.0版本,优化落子位置判断,避免用户选择落子在已有棋子的位置;
    2. 优化获取当前棋局合法移动位置的函数,缩短AI思考时间,平均时长40s,基本保持AI智能程度不变,对弈难度不降低。
  • Version 2.0史诗级重大更新
    1. 增加GUI界面用户选择落子位置方式改为鼠标点击,对弈过程更直观易读;
    2. 保持原有AI智能程度,难度适中,测试中暂未出现无厘头的落子情况。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/53059.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于拉普拉斯金字塔的图像融合

仅为笔记,供自己使用。 读入两幅大小相同的图像 img1 img2;构建 img1 img2的 高斯金字塔,层数根据需要设定(本实验为7层);根据高斯金字塔和拉普拉斯金字塔的关系,推出拉普拉斯金字塔的Li&#…

Open3D 点云均值滤波

目录 一、算法原理1、均值滤波2、参考文献二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理 1、均值滤波 对待处理的当前采样点,选择一个模板,该模板由其邻近的若干个数据点组成,…

Linux 下 Mysql 的使用(Ubuntu20.04)

文章目录 一、安装二、使用2.1 登录2.2 数据库操作2.2.1 创建数据库2.2.2 删除数据库2.2.3 创建数据表 参考文档 一、安装 Linux 下 Mysql 的安装非常简单,一个命令即可: sudo apt install mysql-server检查安装是否成功,输入: …

【推荐】Spring与Mybatis集成

目录 1.概述 2.集成 2.1代码演示: 3.整合 3.1概述 3.2 进行整合分页 接着上两篇,我已经写了Mybatis动态之灵活使用,mybatis的分页和特殊字符的使用方式接下来把它们集成起来,是如何的呢👇👇&#x1…

【Linux应用部署篇】在CSDN云IDE平台部署Etherpad文档编辑器

【Linux应用部署篇】在CSDN云IDE平台部署Etherpad文档编辑器 一、CSDN云IDE平台介绍1.1 CSDN云IDE平台简介1.2 CSDN云IDE平台特点 二、本次实践介绍2.1 本次实践介绍2.2 Etherpad简介 三、登录CSDN云IDE平台3.1 登录CSDN开发云3.2 登录云IDE3.3 新建工作空间3.4 进入工作空间 四…

足球- EDA的历史数据分析并可视化

足球- EDA的历史数据分析并可视化 背景数据介绍探索数据时需要遵循的一些方向:数据处理导入库数据探索 数据可视化赛事分析主客场比分相关性分析时间序列分析 总结 背景 该数据集包括从1872年第一场正式比赛到2023年的44,341场国际足球比赛的结果。比赛范围从FIFA世…

海运费查询国际海运费知识-箱讯科技

在国际贸易中,海运是一种常见且重要的货物运输方式。了解海运费用及其查询方法以及国际海运费的相关知识对于进出口商和物流从业人员来说至关重要。本文将介绍海运费查询的方法和国际海运费的相关知识,帮助读者更好地理解和应用于实际业务中。 一、海运费…

postgresql创建一个只读账户指定数据库

要在 PostgreSQL 中创建一个只读账户,您可以按照以下步骤进行操作: 1. **登录到 PostgreSQL:** 使用具有足够权限的管理员账户(通常是 "postgres" 用户)连接到 PostgreSQL 数据库。 2. **创建只读账户&…

Spring和mybatis整合

一、Spring整合MyBatis 1. 导入pom依赖 1.1 添加spring相关依赖(5.0.2.RELEASE) spring-core spring-beans spring-context spring-orm spring-tx spring-aspects spring-web 1.2 添加mybatis相关依赖 mybatis核心:mybatis(3.4.5) Mybatis分页:pagehel…

Smartbi电子表格软件版本更新,首次推出Excel轻应用和语音播放

Smartbi电子表格软件又又又更新啦! 此次更新,首次推出了新特性——Excel轻应用和语音播报。另外,还对产品功能、Demo示例、配套文档进行了完善和迭代。 低代码开发Excel轻应用 可实现迅速发布web应用 业务用户的需求往往都处于“解决问题”…

结构型模式-代理模式

代理模式* 定义:在代理模式(Proxy Pattern)中,一个类代表另一个类的功能。这种类型的设计模式属于结构型模式。在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口。 意图:为其…

MySQL的日志undolog、binlog、redolog

1. 日志层次 binlog是Server层,undolog和redolog是innodb引擎层特有的。 2. 记录了什么 & 作用 binlog 记录了所有数据库结构变更和表数据修改的SQL日志。 主要用于数据备份和主从复制,比如误删数据了可以用binlog找回。 undolog 如下图&#…

IET独立出版 | EI检索 | 2023年第三届机械、航空航天与汽车工程国际会议

会议简介 Brief Introduction 2023年第三届机械、航空航天与汽车工程国际会议(CMAAE 2023) 会议时间:2023年12月8 -10日 召开地点:中国南京 大会官网:www.cmaae.org 航天是当今世界最具挑战性和广泛带动性的高技术领域…

火山引擎边缘云,助你沉浸式回忆童年

发现了吗?在抖音、西瓜视频上能观看4K修复的经典港片了!得益于抖音、中国电影资料馆、火山引擎共同发起的“经典香港电影修复计划”,我们童年时期看过的《大话西游之大圣娶亲》《武状元苏乞儿》等22部港片以更清晰、流畅、颜色饱满的状态回归…

免300认证费小程序认证进件服务商助手SAAS平台 +小程序前端在线上传

微信小程序公众号SaaS管理系统是一款微信第三方管理系统,为中小企业提供最佳的小程序集中管理解决方案。系统免授权,可实现小程序的快速免审核注册(免300元审核费),支持微信商户进件、支付宝商户进件。整体测试下来使用无问题,前羰小程序认证通道均正常,使用小程序注册认…

学习分享:Ubuntu 下使用 Qt 打开串口报错 Permission denied

Ubuntu 下使用 Qt 打开串口报错 Permission denied 错误描述 提前声明一下,开发环境是 Ubuntu18.04,用户是非 root 用户。 因项目需求,需要使用到 Qt 收发串口数据,曾经写过一个串口调试助手的程序 通俗易懂玩QT:串口…

概率论作业啊啊啊

1 数据位置 (Measures of location) 对于数据集: 7 , 9 , 9 , 10 , 10 , 11 , 11 , 12 , 12 , 12 , 13 , 14 , 14 , 15 , 16 7,9,9,10,10,11,11,12,12,12,13,14,14,15,16 7,9,9,10,10,11,11,12,12,12,13,14,14,15,16 计算加权平均数,其中权重为: 2 , 1 , 3 , 2 ,…

SpringBootWeb 登录认证

登录认证,那什么是认证呢? 所谓认证指的就是根据用户名和密码校验用户身份的这个过程,认证成功之后,我们才可以访问系统当中的信息,否则就拒绝访问。 在前面的案例中,我们已经实现了部门管理、员工管理的…

强化学习系列--带基准线的REINFORCE算法

强化学习系列--带基准线的REINFORCE算法 介绍示例代码 介绍 在强化学习中,带基准线的REINFORCE算法是一种用于求解策略梯度的方法。REINFORCE算法(也称为蒙特卡洛策略梯度算法)可以用于训练能够从环境中学习的策略。带基准线的REINFORCE算法…

Pytorch建立MyDataLoader过程详解

简介 torch.utils.data.DataLoader(dataset, batch_size1, shuffleNone, samplerNone, batch_samplerNone, num_workers0, collate_fnNone, pin_memoryFalse, drop_lastFalse, timeout0, worker_init_fnNone, multiprocessing_contextNone, generatorNone, *, prefetch_factorN…