php实现tic-tac-toe,在Python中实现Tic-Tac-Toe的Minimax算法

我正在为Tic-Tac-Toe机器人创建一个简单的minimax算法。我在这里读了一些其他的答案,但是我仍然不确定我做错了什么,我对递归函数还很陌生。我想我知道算法是怎么工作的,但我不太确定。在def minimax(board, player, originalPlayer):

global ai, human

if gameOver(board):

if hasWon(board, originalPlayer):

return 1, None

if hasWon(board, opposite(originalPlayer)):

return -1, None

if len(getEmptyIndexes(board)) is 0:

return 0, None

possibleMoves = getEmptyIndexes(board)

if player == originalPlayer:

bestScore = float('-inf')

else:

bestScore = float('inf')

for moveIndex in possibleMoves:

clone = copy(board)

clone = makeMove(clone, moveIndex, player)

score, index = minimax(clone, opposite(player), originalPlayer)

if player == originalPlayer:

if score > bestScore:

bestScore = score

bestMove = index

else:

if score < bestScore:

bestScore = score

bestMove = index

return bestScore, bestMove

我的游戏循环在下面,我只是用它来调试。我得到的错误是minimax函数返回元组(0,None),而我期望得到None所在的板的索引。在

^{pr2}$

谢谢你的帮助!在

编辑:

getEmptyIndexes返回板上空格的索引;例如:

^{3}$

编辑2:

我想我实际上只是修复了它,我写的是“bestMove=index”而不是“bestMove=moveIndex”,我用的是老叶子节点的旧移动索引,而不是新节点。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值