網站首頁 編程語言 正文
本文實例為大家分享了python實現人機對戰井字棋的具體代碼,供大家參考,具體內容如下
游戲簡介:在九宮格內進行,如果一方搶先于另一方向(橫、豎、斜)連成3子,則獲得勝利。游戲中輸入方格位置代號的形式如下:
設計前的思路:
游戲中,board棋盤存儲玩家、計算機的落子信息,未落子處未EMPTY。由于人機對戰,需要實現計算機智能性,下面是為這個計算機機器人設計的簡單策略:
如果有一步棋可以讓計算機機器人在本輪獲勝,那就選那一步走。
否則,如果有一步棋可以讓玩家在本輪獲勝,那就選那一步走。
否則,計算機機器人應該選擇最佳位置來走。
最佳位置就是中間,其次是四個角
定義第一個元組best_weizhi存儲最佳方格位置:
按優劣順序排序的下棋位置
best_weizhi= (4, 0, 2, 6, 8, 1, 3, 5, 7)
井字棋盤輸贏判斷規則只有8種方式。每種獲勝方式都被寫成一個元組,利用嵌套元組表達:
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 = " "
#定義函數產生一個新的棋盤
def new_board():
? ? board = []
? ? for square in range(9):
? ? ? ? board.append(EMPTY)
? ? return board
#詢問該誰下棋
def ask_yes_no(question):
? ? response = None
? ? #如果輸入不是"y", "n",繼續重新輸入
? ? while response not in ("y", "n"):?? ?
? ? ? ? ? ?response = input(question).lower()
? ? return response
#詢問誰先走,先走方為X,后走方為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[:] ? ? #創建副本,修改不影響原來列表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")
#輸入你想下的位置數字
def ask_number(question, low, high):
? ? response = None
? ? while response not in range(low, high):
? ? ? ? response = int(input(question))
? ? return response
#產生可以合法走棋位置序列(也就是還未下過子位置)
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"?? ??? ??? ?#"平局和棋,游戲結束"
? ? return False
#人走棋
def human_move(board, human):
? ? legal = legal_moves(board)
? ? move = None
? ? while move not in legal:
? ? ? ? move = ask_number("你走那個位置? (0 - 9):", 0, 9)
? ? ? ? if move not in legal:
? ? ? ? ? ? print("\n此位置已經落過子了")
? ? return move
#電腦走棋
def computer_move(board, computer, human):
? ? # make a copy to work with since function will be changing list
? ? board = board[:] ? ? #創建副本,修改不影響原來列表board
? ? #按優劣順序排序的下棋位置best_weizhi
? ? # 如果電腦能贏,就走那個位置
? ? for move in legal_moves(board):
? ? ? ? board[move] = computer
? ? ? ? if winner(board) == computer:
? ? ? ? ? ? print("電腦下棋位置是" ,move)
? ? ? ? ? ? return move
? ? ? ? # 取消走棋方案
? ? ? ? board[move] = EMPTY
? ? # 如果玩家能贏,就堵住那個位置
? ? for move in legal_moves(board):
? ? ? ? board[move] = human
? ? ? ? if winner(board) == human:
? ? ? ? ? ? print("電腦下棋位置是" ,move)
? ? ? ? ? ? return move
? ? ? ? #取消走棋方案
? ? ? ? board[move] = EMPTY
? ? #不是上面情況則,也就是這一輪時都贏不了則
? ? #從最佳下棋位置表中挑出第一個合法位置
? ? for move in best_weizhi:
? ? ? ? if move in legal_moves(board):
? ? ? ? ? ? print("電腦下棋位置是" ,move)
? ? ? ? ? ? return move
#轉換角色
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)
? ? #游戲結束輸出輸贏信息
? ? if the_winner == computer:
? ? ? ? print("電腦贏!\n") ? ?
? ? elif the_winner == human: ? ? ? ??
? ? ? ? print("玩家贏!\n")
? ? elif the_winner == "True":?? ?#"平局" ? ? ? ?
? ? ? ? print("平局,和棋,游戲結束\n")
# start the program
main()
input("按任意鍵退出游戲.")
在最后附上結果圖:
至此一個簡單的井字棋就完成了。
原文鏈接:https://blog.csdn.net/ydydyd00/article/details/82895909
相關推薦
- 2022-06-12 C語言實題講解快速掌握單鏈表上_C 語言
- 2022-04-07 C++?string與int的相互轉換(使用C++11)_C 語言
- 2023-01-31 Android如何實現一個DocumentProvider示例詳解_Android
- 2022-11-06 Git?Commitizen提交規范化自動生成changelog文件_相關技巧
- 2022-07-24 Android中關于定時任務實現關閉訂單問題_Android
- 2022-07-04 Python+Pillow+Pytesseract實現驗證碼識別_python
- 2021-12-19 C/C++?Qt?TabWidget?實現多窗體創建詳解_C 語言
- 2022-07-22 如何測試webservice接口
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支