網(wǎng)站首頁 編程語言 正文
本文實(shí)例為大家分享了python實(shí)現(xiàn)人機(jī)對(duì)戰(zhàn)井字棋的具體代碼,供大家參考,具體內(nèi)容如下
游戲簡介:在九宮格內(nèi)進(jìn)行,如果一方搶先于另一方向(橫、豎、斜)連成3子,則獲得勝利。游戲中輸入方格位置代號(hào)的形式如下:
設(shè)計(jì)前的思路:
游戲中,board棋盤存儲(chǔ)玩家、計(jì)算機(jī)的落子信息,未落子處未EMPTY。由于人機(jī)對(duì)戰(zhàn),需要實(shí)現(xiàn)計(jì)算機(jī)智能性,下面是為這個(gè)計(jì)算機(jī)機(jī)器人設(shè)計(jì)的簡單策略:
如果有一步棋可以讓計(jì)算機(jī)機(jī)器人在本輪獲勝,那就選那一步走。
否則,如果有一步棋可以讓玩家在本輪獲勝,那就選那一步走。
否則,計(jì)算機(jī)機(jī)器人應(yīng)該選擇最佳位置來走。
最佳位置就是中間,其次是四個(gè)角
定義第一個(gè)元組best_weizhi存儲(chǔ)最佳方格位置:
按優(yōu)劣順序排序的下棋位置
best_weizhi= (4, 0, 2, 6, 8, 1, 3, 5, 7)
井字棋盤輸贏判斷規(guī)則只有8種方式。每種獲勝方式都被寫成一個(gè)元組,利用嵌套元組表達(dá):
win = ((0, 1, 2), (3, 4, 5), (6, 7, 8), (0, 3, 6),(1, 4, 7), (2, 5, 8), (0, 4, 8), (2, 4, 6))
代碼:
#全局常量
best_weizhi= (4, 0, 2, 6, 8, 1, 3, 5, 7)
win = ((0, 1, 2), ?(3, 4, 5), (6, 7, 8), ?(0, 3, 6),(1, 4, 7), ?(2, 5, 8), (0, 4, 8), ?(2, 4, 6))?
X = "X"
O = "O"
EMPTY = " "
#定義函數(shù)產(chǎn)生一個(gè)新的棋盤
def new_board():
? ? board = []
? ? for square in range(9):
? ? ? ? board.append(EMPTY)
? ? return board
#詢問該誰下棋
def ask_yes_no(question):
? ? response = None
? ? #如果輸入不是"y", "n",繼續(xù)重新輸入
? ? while response not in ("y", "n"):?? ?
? ? ? ? ? ?response = input(question).lower()
? ? return response
#詢問誰先走,先走方為X,后走方為O
#函數(shù)返回電腦方、玩家的角色代號(hào)
def pieces():
? ? go_first = ask_yes_no("玩家你是否先走 (y/n): ")
? ? if go_first == "y":
? ? ? ? print("\n玩家你先走.")
? ? ? ? human = X
? ? ? ? computer = O
? ? else:
? ? ? ? print("\n電腦先走.")
? ? ? ? computer = X
? ? ? ? human = O
? ? return computer, human
#顯示棋盤
def display_board(board):
? ? board2=board[:] ? ? #創(chuàng)建副本,修改不影響原來列表board
? ? for i in range(len(board)):
? ? ? ? if board[i]==EMPTY:
? ? ? ? ? ? board2[i]=i
? ? print("\t", board2[0], "|", board2[1], "|", board2[2])
? ? print("\t", "---------")
? ? print("\t", board2[3], "|", board2[4], "|", board2[5])
? ? print("\t", "---------")
? ? print("\t", board2[6], "|", board2[7], "|", board2[8], "\n")
#輸入你想下的位置數(shù)字
def ask_number(question, low, high):
? ? response = None
? ? while response not in range(low, high):
? ? ? ? response = int(input(question))
? ? return response
#產(chǎn)生可以合法走棋位置序列(也就是還未下過子位置)
def legal_moves(board):
? ? moves = []
? ? for i in range(9):
? ? ? ? if board[i] == EMPTY:
? ? ? ? ? ? moves.append(i)
? ? return moves
#判斷輸贏
def winner(board):
? ? for row in win:
? ? ? ? if board[row[0]] == board[row[1]] == board[row[2]] != EMPTY:
? ? ? ? ? ? winner = board[row[0]]
? ? ? ? ? ? return winner ? ? ? #返回贏方
? ? #棋盤沒有空位置
? ? if EMPTY not in board:
? ? ? ? return "True"?? ??? ??? ?#"平局和棋,游戲結(jié)束"
? ? return False
#人走棋
def human_move(board, human):
? ? legal = legal_moves(board)
? ? move = None
? ? while move not in legal:
? ? ? ? move = ask_number("你走那個(gè)位置? (0 - 9):", 0, 9)
? ? ? ? if move not in legal:
? ? ? ? ? ? print("\n此位置已經(jīng)落過子了")
? ? return move
#電腦走棋
def computer_move(board, computer, human):
? ? # make a copy to work with since function will be changing list
? ? board = board[:] ? ? #創(chuàng)建副本,修改不影響原來列表board
? ? #按優(yōu)劣順序排序的下棋位置best_weizhi
? ? # 如果電腦能贏,就走那個(gè)位置
? ? for move in legal_moves(board):
? ? ? ? board[move] = computer
? ? ? ? if winner(board) == computer:
? ? ? ? ? ? print("電腦下棋位置是" ,move)
? ? ? ? ? ? return move
? ? ? ? # 取消走棋方案
? ? ? ? board[move] = EMPTY
? ? # 如果玩家能贏,就堵住那個(gè)位置
? ? for move in legal_moves(board):
? ? ? ? board[move] = human
? ? ? ? if winner(board) == human:
? ? ? ? ? ? print("電腦下棋位置是" ,move)
? ? ? ? ? ? return move
? ? ? ? #取消走棋方案
? ? ? ? board[move] = EMPTY
? ? #不是上面情況則,也就是這一輪時(shí)都贏不了則
? ? #從最佳下棋位置表中挑出第一個(gè)合法位置
? ? for move in best_weizhi:
? ? ? ? if move in legal_moves(board):
? ? ? ? ? ? print("電腦下棋位置是" ,move)
? ? ? ? ? ? return move
#轉(zhuǎn)換角色
def next_turn(turn):
? ? if turn == X:
? ? ? ? return O
? ? else:
? ? ? ? return X
#主方法:
def main():
? ? computer, human = pieces()
? ? turn = X
? ? board = new_board()
? ? display_board(board)
? ??
? ? while not winner(board):
? ? ? ? if turn == human:
? ? ? ? ? ? move = human_move(board, human)
? ? ? ? ? ? board[move] = human
? ? ? ? else:
? ? ? ? ? ? move = computer_move(board, computer, human)
? ? ? ? ? ? board[move] = computer
? ? ? ? display_board(board)
? ? ? ? turn = next_turn(turn)
? ? ? ? the_winner = winner(board)
? ? #游戲結(jié)束輸出輸贏信息
? ? if the_winner == computer:
? ? ? ? print("電腦贏!\n") ? ?
? ? elif the_winner == human: ? ? ? ??
? ? ? ? print("玩家贏!\n")
? ? elif the_winner == "True":?? ?#"平局" ? ? ? ?
? ? ? ? print("平局,和棋,游戲結(jié)束\n")
# start the program
main()
input("按任意鍵退出游戲.")
在最后附上結(jié)果圖:
至此一個(gè)簡單的井字棋就完成了。
原文鏈接:https://blog.csdn.net/ydydyd00/article/details/82895909
相關(guān)推薦
- 2022-05-13 初識(shí)C++ 引用&內(nèi)聯(lián)函數(shù)
- 2023-04-20 npm ERR! 400 Bad Request - PUT xxx - Cannot publis
- 2022-06-17 使用Python解決常見格式圖像讀取nii,dicom,mhd_python
- 2022-04-11 jackson中對(duì)null的處理
- 2022-11-08 PostgreSQL查看帶有綁定變量SQL的通用方法詳解_PostgreSQL
- 2022-08-22 優(yōu)雅使用GoFrame共享變量Context示例詳解_Golang
- 2022-05-31 postman批量執(zhí)行接口測(cè)試的圖文步驟_其它綜合
- 2022-11-16 常用的Git便捷操作合集_相關(guān)技巧
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支