知识大全 VB.NET实现五子棋的人工智能-1

Posted 计算机

篇首语:心静可以生慧,行善方能得福。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 VB.NET实现五子棋的人工智能-1相关的知识,希望对你有一定的参考价值。

VB.NET实现五子棋的人工智能-1  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  人工智能也就是所谓的AI(Artificial Intelligence) 是一门很抽象的技术 AI程序的编写不需要依据任何既定的思考模式或者规则 尤其是游戏中的AI可以完全依程序设计者本身的思考逻辑制作 我个人认为人工智能的核心应该是使计算机具有自动的处理事件的能力 而我们的所有的研究也应该围绕着这一方向 主体是策略类的人工智能

  策略类人工智能可以说是AI中比较复杂的一种 最常见的策略类AI游戏就是棋盘式游戏 在这类游戏中 通常的策略类AI程序都是使计算机判断目前状况下所有可走的棋与可能的获胜状况 并计算当前计算机可走棋步的获胜分数或者玩家可走棋步的获胜分数 然后再决定出一个最佳走法 下面先介绍一下五子棋的AI构想

  五子棋的AI构想

  有句话叫 当局者迷 旁观者清 但这句话在由AI所控制的计算机玩家上是不成立的 因为计算机必须知道有那些获胜方式 并计算出每下一步棋到棋盘上任一格子的获胜几率 也就是说 一个完整的五子棋的AI构想必须     能够知道所有的获胜组合

   建立和使用获胜表

   设定获胜的分数

   使电脑具有攻击和防守的能力

  一 求五子棋的获胜组合

  在一场五子棋的游戏中 计算机必须要知道有那些的获胜组合 因此我们必须求得获胜组合的总数 我们假定当前的棋盘为 *

  ( )计算水平方向的获胜组合数 每一列的获胜组合是 共 列 所以水平方向的获胜组合数为 * =

  ( )计算垂直方向的获胜组合总数 每一行的获胜组合是 共 行 则垂直方向的获胜组合数为 * =

  ( )计算正对角线方向的获胜组合总数 正对角线上的获胜组合总数为

   +( + + + + )* =

  ( )计算反对角线方向的获胜组合总数 反对角线上的获胜组合总数为   +( + + + + )* = 这样所有的获胜组合数为 + + + =

  二 建立和使用获胜表

  我们已经计算出了一个 * 的五子棋盘会有 种获胜方式 这样我们可以利用数组建立获胜表 获胜表的主要作用是 判断当前的获胜方式是否有效 判断当前的获胜方式中到底有多少子落入该获胜组合中 详细的使用您将在后面的程序中可以看出

  三 分数的设定

  在游戏中为了让计算机能够决定下一步最佳的走法 必须先计算出计算机下到棋盘上任一空格的分数 而其中最高分数便是计算机下一步的最佳走法

  原理 我们判定当前讨论的空格与当前讨论的点有几种获胜的方式 有几种该空格就加几分 这种原理初听起来似乎是无法入手 没关系 当您了解我们后面的程序后您就会明白这种决策原理了

  这种决策有一些缺陷 因为如果只根据这个模型设计 就有可能出现电脑或玩家有三个子连成一线的时候 计算机却判断不出 它认为其他某些空格是当前的获胜的最佳位置而不去攻击或防守 没关系我们完全可以通过一个加强算法来改变当前的分值情况 也就是说当电脑或玩家有三个子或四个子连成一线时 我们通过加强算法将当前与三个子或四个子有关的空格的分值提高 从而可以弥补这一缺憾

  四 攻击与防守

  以上的方式 事实上计算机只是计算出了最佳的攻击位置 为了防守我们还应计算当前玩家的最佳的攻击位置 这样有什么用呢?道理很简单 如果玩家最佳攻击位置的分数大于计算机最佳攻击位置上的分数 那么计算机就将下一步的棋子摆在玩家的最佳攻击位上以阻止玩家的进攻 否则计算机便将棋子下在自己的最佳攻击位置上进行攻击

  事实上 这个AI构想是很强大的如果你不是很厉害的五子棋高手的话 可能很快会被计算机打败 我在联众上可是中级棋手啊 跟这种构想打的时候胜率也不是很高

  使用编写五子棋

  一 编写前的准备

   用计算机的思想描述整个下棋的过程

  考虑步骤

  ( )为了简便我们可以先让电脑先走第一步棋 电脑每走一步就会封掉许多玩家的获胜可能情况

  ( )当玩家走棋的时候我们首先应该考虑玩家走棋的合法性

  ( )如果合法 那么玩家也会封掉许多电脑的获胜的可能情况

  ( )电脑的思考路径 首先判断当前玩家和电脑的所有获胜组合是否需要进行加强赋值 是进行加强赋值 否则进行普通的赋值

  ( )比较当前玩家和电脑谁的分值最大 将分值最大的点作为电脑的下一步走法

   利用窗体和图形工具建立五子棋的棋盘界面

  ( )添加一个picturebox控件

  作用 使用picturebox控件绘制棋子和棋盘

  ( )添加一个label控件

  作用 显示当前的获胜标志 也就是当某一方获胜或和棋时显示此标签

  ( )添加一个mainmenu控件

  作用 控制游戏的开始或结束

  ( )添加一个mediaplay组件

  作用 使程序可以播放音乐

   设置整体框价

  我们采取 * 的棋盘 为主要的平台 利用数组定义整个棋盘桌面 利用数组定义获胜组合以及获胜标志等

  二 声明全局数组和变量

  定义虚拟桌面

  Dim table( ) As Integer  定义当前玩家桌面空格的分数

  Dim pscore( ) As Integer  定义当前电脑桌面空格的分数

  Dim cscore( ) As Integer  定义玩家的获胜组合

  Dim pwin( ) As Boolean  定义电脑的获胜组合

  Dim cwin( ) As Boolean  定义玩家的获胜组合标志

  Dim pflag( ) As Boolean  定义电脑的获胜组合标志

  Dim cflag( ) As Boolean  定义游戏有效标志

cha138/Article/program/ASP/201311/21668

相关参考

知识大全 VB.NET中对象的克隆[1]

VB.NET中对象的克隆[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在DMAX里面做好

知识大全 VB.NET菜单设计初级入门[1]

VB.NET菜单设计初级入门[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  可视化编程工具

知识大全 VB.NET和C#逐层横向对比[1]

VB.NET和C#逐层横向对比[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  //全局层 

知识大全 用VB.NET 2005编写定时关机程序[1]

用VB.NET2005编写定时关机程序[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&nbs

知识大全 VB.Net编程入门之Hello World(1)

VB.Net编程入门之HelloWorld(1)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  

知识大全 VB.net2008精彩实例,窗体应用技巧[1]

VB.net2008精彩实例,窗体应用技巧[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  

知识大全 用VB.net2008打造你的影音播放器[1]

用VB.net2008打造你的影音播放器[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  本

知识大全 从VB 6迁移到VB.NET的进展至今仍旧缓慢

从VB6迁移到VB.NET的进展至今仍旧缓慢  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!在发布V

知识大全 VB.NET中声音的播放

VB.NET中声音的播放  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 由VB升级为NET后有些人

知识大全 与VB .NET一起使用.NET Framework

与VB.NET一起使用.NETFramework  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!