欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)人機對戰(zhàn)的井字棋游戲

 更新時間:2022年04月27日 12:46:38   作者:IT老實人  
這篇文章主要為大家詳細介紹了python實現(xiàn)人機對戰(zhàn)的井字棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了python實現(xiàn)人機對戰(zhàn)井字棋的具體代碼,供大家參考,具體內(nèi)容如下

游戲簡介:在九宮格內(nèi)進行,如果一方搶先于另一方向(橫、豎、斜)連成3子,則獲得勝利。游戲中輸入方格位置代號的形式如下:

設(shè)計前的思路:

游戲中,board棋盤存儲玩家、計算機的落子信息,未落子處未EMPTY。由于人機對戰(zhàn),需要實現(xiàn)計算機智能性,下面是為這個計算機機器人設(shè)計的簡單策略:
如果有一步棋可以讓計算機機器人在本輪獲勝,那就選那一步走。
否則,如果有一步棋可以讓玩家在本輪獲勝,那就選那一步走。
否則,計算機機器人應(yīng)該選擇最佳位置來走。
最佳位置就是中間,其次是四個角
定義第一個元組best_weizhi存儲最佳方格位置:
按優(yōu)劣順序排序的下棋位置
best_weizhi= (4, 0, 2, 6, 8, 1, 3, 5, 7)
井字棋盤輸贏判斷規(guī)則只有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 = " "
#定義函數(shù)產(chǎn)生一個新的棋盤
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ù)返回電腦方、玩家的角色代號
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("你走那個位置? (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
? ? # 如果電腦能贏,就走那個位置
? ? 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
#轉(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é)果圖:

至此一個簡單的井字棋就完成了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • pd.drop_duplicates刪除重復(fù)行的方法實現(xiàn)

    pd.drop_duplicates刪除重復(fù)行的方法實現(xiàn)

    drop_duplicates 方法實現(xiàn)對數(shù)據(jù)框 DataFrame 去除特定列的重復(fù)行,本文主要介紹了pd.drop_duplicates刪除重復(fù)行的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Python?中?Pandas?文件操作和讀取?CSV?參數(shù)詳解

    Python?中?Pandas?文件操作和讀取?CSV?參數(shù)詳解

    CSV?又稱逗號分隔值文件,是一種簡單的文件格式,以特定的結(jié)構(gòu)來排列表格數(shù)據(jù),這篇文章主要介紹了Python?之?Pandas?文件操作和讀取?CSV?參數(shù)詳解,需要的朋友可以參考下
    2023-03-03
  • 在Python中使用模塊的教程

    在Python中使用模塊的教程

    這篇文章主要介紹了在Python中使用模塊的教程,示例代碼基于Python2.x版本,需要的朋友可以參考下
    2015-04-04
  • Python利用多線程同步鎖實現(xiàn)多窗口訂票系統(tǒng)(推薦)

    Python利用多線程同步鎖實現(xiàn)多窗口訂票系統(tǒng)(推薦)

    這篇文章主要介紹了Python利用多線程同步鎖實現(xiàn)多窗口訂票系統(tǒng),主要是利用threading.lock()通過實例代碼相結(jié)合給大家講解的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • Python 2.7中文顯示與處理方法

    Python 2.7中文顯示與處理方法

    今天小編就為大家分享一篇Python 2.7中文顯示與處理方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • 利用Python開發(fā)微信支付的注意事項

    利用Python開發(fā)微信支付的注意事項

    如今支付的引入是很多互聯(lián)網(wǎng)產(chǎn)品都需要的。為了讓用戶用著更方便快捷,集成像支付寶、微信支付這樣的第三方支付也就成了常有的事。今天跟著小編就來看看微信支付開發(fā)中幾個值得注意的地方,涉及代碼之處均用 Python 編寫。
    2016-08-08
  • Python逐行讀取文件中內(nèi)容的簡單方法

    Python逐行讀取文件中內(nèi)容的簡單方法

    今天小編就為大家分享一篇關(guān)于Python逐行讀取文件中內(nèi)容的簡單方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • python 數(shù)據(jù)類型強制轉(zhuǎn)換的總結(jié)

    python 數(shù)據(jù)類型強制轉(zhuǎn)換的總結(jié)

    這篇文章主要介紹了python 數(shù)據(jù)類型強制轉(zhuǎn)換的使用總結(jié),幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2021-01-01
  • python中精確的浮點數(shù)運算示例

    python中精確的浮點數(shù)運算示例

    這篇文章主要為大家介紹了python中精確的浮點數(shù)運算示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 修改 CentOS 6.x 上默認Python的方法

    修改 CentOS 6.x 上默認Python的方法

    這篇文章主要介紹了修改 CentOS 6.x 上默認Python的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09

最新評論