- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试通过 Jason Fox ( http://neverstopbuilding.com/minimax ) 实现 minimax 算法,但它不起作用,计算机只是随机移动。这是我编写的 Game
类(我必须创建一个 cloneGrid
函数,因为数组作为引用传递,是否有更好的方法来解决这个问题?):
class Game
{
public enum Piece { Empty = 0, X = 1, O = 2 };
static int[,] winConditions = new int[8, 3]
{
{ 0, 1, 2 }, { 3, 4, 5 }, { 6, 7, 8 },
{ 0, 3, 6 }, { 1, 4, 7 }, { 2, 5, 8 },
{ 0, 4, 8 }, { 2, 4, 6 }
};
public Piece[] Grid = new Piece[9];
public Piece CurrentTurn = Piece.X;
int Choice = 0;
public Piece Computer;
public Piece Player;
public Game()
{
CurrentTurn = Piece.X;
Player = Piece.X;
}
public void Reset()
{
CurrentTurn = Piece.X;
SetPlayer(Piece.X);
Grid = new Piece[9];
}
public void SetPlayer(Piece Player)
{
this.Player = Player;
this.Computer = switchPiece(Player);
}
public void MakeMove(int Move)
{
if(CurrentTurn == Player)
{
Grid = makeGridMove(Grid, CurrentTurn, Move);
CurrentTurn = switchPiece(CurrentTurn);
}
else if(CurrentTurn == Computer)
{
minimax(cloneGrid(Grid), CurrentTurn);
Grid = makeGridMove(Grid, CurrentTurn, Choice);
CurrentTurn = switchPiece(CurrentTurn);
Console.WriteLine(Choice.ToString());
}
}
int minimax(Piece[] InputGrid, Piece Player)
{
Piece[] Grid = cloneGrid(InputGrid);
if (checkScore(Grid, Player) != 0)
return checkScore(Grid, Player);
else if (checkGameEnd(Grid)) return 0;
List<int> scores = new List<int>();
List<int> moves = new List<int>();
for (int i = 0; i < 9; i++)
{
if (Grid[i] == Piece.Empty)
{
scores.Add(minimax(makeGridMove(Grid, Player, i), switchPiece(Player)));
moves.Add(i);
}
}
if(Player == Computer)
{
int MaxScoreIndex = scores.IndexOf(scores.Max());
Choice = moves[MaxScoreIndex];
return scores.Max();
}
else
{
int MinScoreIndex = scores.IndexOf(scores.Min());
Choice = moves[MinScoreIndex];
return scores.Min();
}
}
static int checkScore(Piece[] Grid, Piece Player)
{
if (checkGameWin(Grid, Player)) return 10;
else if (checkGameWin(Grid, switchPiece(Player))) return -10;
else return 0;
}
static bool checkGameWin(Piece[] Grid, Piece Player)
{
for(int i = 0; i < 8; i++)
{
if
(
Grid[winConditions[i, 0]] == Player &&
Grid[winConditions[i, 1]] == Player &&
Grid[winConditions[i, 2]] == Player
)
{
return true;
}
}
return false;
}
static bool checkGameEnd(Piece[] Grid)
{
foreach (Piece p in Grid) if (p == Piece.Empty) return false;
return true;
}
static Piece switchPiece(Piece Piece)
{
if (Piece == Piece.X) return Piece.O;
else return Piece.X;
}
static Piece[] cloneGrid(Piece[] Grid)
{
Piece[] Clone = new Piece[9];
for (int i = 0; i < 9; i++) Clone[i] = Grid[i];
return Clone;
}
static Piece[] makeGridMove(Piece[] Grid, Piece Move, int Position)
{
Piece[] newGrid = cloneGrid(Grid);
newGrid[Position] = Move;
return newGrid;
}
}
最佳答案
这很愚蠢,但错误是我正在检查当前玩家的分数,但它应该只检查 AI。所以解决方案是使用:checkScore(Grid, Computer),而不是 checkScore(Grid, Player)
关于c# - Tic Tac Toe 的 Minimax 算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32425162/
我是初学者,所以我的代码很乱。我还没有完整地评论这个游戏,所以如果你需要澄清一些变量,我可以给你。 (顺便说一句,这是一个要求制作井字游戏的c++项目) 我的主要问题是,我将如何重复我的棋盘(每次有人
本文实例讲述了Python实现的井字棋(Tic Tac Toe)游戏。分享给大家供大家参考,具体如下: 说明 用python实现了井字棋,整个框架是本人自己构思的,自认为比较满意。另外,90%+
这个教程,我们将展示如何用python创建一个井字游戏。 其中我们将使用函数、数组、if条件语句、while循环语句和错误捕获等。 首先我们需要创建两个函数,第一个函数用来显示游戏板:
我正在尝试从命令行(使用终端)以相反的顺序搜索大文件。我找到了 tac 命令:http://clifgriffin.com/2008/11/25/tac-and-reverse-grep/ tac 是
在阅读时,我遇到了“中级语言”和“3AC”这两个术语。 据我了解,IL 是源代码编译过程中的中间“步骤”。更具体地说,我正在阅读有关字节码(Java)和 C 的内容。 我解释它的方式(如果错了请纠正我
我正在为C的Tic Tac Toe代码编写一个简单的游戏。我已经完成了大部分代码,但是我希望AI永不丢失。 我已经阅读了有关minimax算法的信息,但我不理解。如何使用此算法使计算机获胜或平局,但永
我正在尝试使用reactjs创建一个简单的井字棋应用程序,其中有两种模式:经典和图像,在经典模式下我可以选择显示 X 和 O,在图像模式下,我可以选择两个显示下面提到的两个图像。我的文件结构是: sr
我想将普通的三地址代码文件转换为 Java 字节码。已经有一些与此主题相关的问题,但没有得到解答 properly或question远远超出了我正在寻找的范围。 以《龙书》中的编译器前端生成的这段代码
我试图解决 Schwartz 的“学习 Perl”中的一个练习,这时我在编写的代码中偶然发现了意外的输出。我想知道我做错了什么。 Qn:实现一个类似于 unix 实用程序的简单 tac。 我的解决方案
我有一份非常通用的工作,不同的参数作为来自不同文件的上下文参数传递。但我仍然需要“硬编码”上下文文件名并在 TAC (Talend Administration Console) 中创建多个作业以供执
我现在想用我的代码做两件事。1) 检查获胜者2) 不让双方玩家在同一个位置进入eg.如果player1已经在board[0][0]='X'处输入了value,player2再次进入board[0][0
我有一个扭曲的 tac 文件 (twisted_service.py),其中包含代码: from twisted.application import service # application.py
我是 UNIX 编码的新手,我有一个文件需要逐行反向读取。该文件在 {} 中有代码段。然后我需要使用这个反向文件作为输入来运行一个 awk 脚本。我正在让我们的支持人员安装 tac,但在他们安装之前,
感谢这里人们的帮助,我成功地禁用了点击 div 并在已经使用 $(".pos").addClass('already-played'); 选择它们时覆盖它们; 以及 CSS 中的这个: .已经播放{
我有一个井字棋游戏,其中用户(x)玩CPU(o)。游戏开始时,CPU 将 (o) 放置在中心,并在用户之后移动到随机位置。游戏设置为循环,但一旦出现获胜者,它就会重置,并且不会显示“你赢/输的横幅”。
我试图在没有人工智能的情况下实现井字棋游戏。不知怎的,我的点击功能会自动触发。您能帮我理解为什么点击功能会自动触发吗?这是 HTML 代码片段。 Tic Tac Toe Gam
我正在制作一个井字游戏程序。我计划将 minimax 与它一起使用。我制作了一棵树,其中包含所有可能的游戏序列的空间,并且我正在寻找一种方法来填充它。我目前有这种类型: typedef struct
我在完成这项学校作业时遇到了问题。我想实现一种方法,其中代码显示 //call method to check for Winner,在每轮后检查获胜者。 我不确定该怎么做。我尝试过各种不同的方法。然
我正在尝试遵循本教程: https://www.youtube.com/watch?v=Db3cC5iPrOM 2:59 我听不懂他在说什么。 我不明白为什么他在构造函数(public static
问题很简单。我有一个 IMEI,我想从中检索 TAC。我该怎么做?如果我只有 IMEI,是否有办法识别 TAC 应该有多少位数字?是否需要明确知道设备的生产年份才能知道? 最佳答案 从头开始读取 8
我是一名优秀的程序员,十分优秀!