日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python實現單機五子棋

瀏覽:15日期:2022-07-13 08:01:58

簡介

這是實驗室2018年底招新時的考核題目,使用Python編寫一個能夠完成基本對戰的五子棋游戲。面向新手。

程序主要包括兩個部分,圖形創建與邏輯編寫兩部分。

程序的運行結果:

python實現單機五子棋

樣式創建

老規矩,先把用到的包導入進來。

’’’@Auther : gaoxin@Date : 2019.01.01@Version : 1.0’’’from tkinter import *import math

然后建立一個樣式的類,類名稱chessBoard。這里加了很多注釋,避免新手看不懂函數的作用,說實話我覺得挺別扭的。

#定義棋盤類class chessBoard() : def __init__(self) : #創建一個tk對象,即窗口 self.window = Tk() #窗口命名 self.window.title('五子棋游戲') #定義窗口大小 self.window.geometry('660x470') #定義窗口不可放縮 self.window.resizable(0,0) #定義窗口里的畫布 self.canvas=Canvas(self.window , bg='#EEE8AC' , width=470, height=470) #畫出畫布內容 self.paint_board() #定義畫布所在的網格 self.canvas.grid(row = 0 , column = 0) def paint_board(self) : #畫橫線 for row in range(0,15) : if row == 0 or row == 14 : self.canvas.create_line(25 , 25+row*30 , 25+14*30 , 25+row*30 , width = 2) else : self.canvas.create_line(25 , 25+row*30 , 25+14*30 , 25+row*30 , width = 1) #畫豎線 for column in range(0,15) : if column == 0 or column == 14 : self.canvas.create_line(25+column*30 ,25, 25+column*30 , 25+14*30 ,width = 2) else : self.canvas.create_line(25+column*30 ,25, 25+column*30 , 25+14*30 , width = 1) #畫圓 self.canvas.create_oval(112, 112, 118, 118, fill='black') self.canvas.create_oval(352, 112, 358, 118, fill='black') self.canvas.create_oval(112, 352, 118, 358, fill='black') self.canvas.create_oval(232, 232, 238, 238, fill='black') self.canvas.create_oval(352, 352, 358, 358, fill='black')

邏輯編寫

這里的主要看每個函數的功能就好了。

#定義五子棋游戲類#0為黑子 , 1為白子 , 2為空位class Gobang() : #初始化 def __init__(self) : self.board = chessBoard() self.game_print = StringVar() self.game_print.set('') #16*16的二維列表,保證不會out of index self.db = [([2] * 16) for i in range(16)] #悔棋用的順序列表 self.order = [] #棋子顏色 self.color_count = 0 self.color = ’black’ #清空與贏的初始化,已贏為1,已清空為1 self.flag_win = 1 self.flag_empty = 1 self.options() #黑白互換 def change_color(self) : self.color_count = (self.color_count + 1 ) % 2 if self.color_count == 0 : self.color = 'black' elif self.color_count ==1 : self.color = 'white' #落子 def chess_moving(self ,event) : #不點擊“開始”與“清空”無法再次開始落子 if self.flag_win ==1 or self.flag_empty ==0 : return #坐標轉化為下標 x,y = event.x-25 , event.y-25 x = round(x/30) y = round(y/30) #點擊位置沒用落子,且沒有在棋盤線外,可以落子 while self.db[y][x] == 2 and self.limit_boarder(y,x): self.db[y][x] = self.color_count self.order.append(x+15*y) self.board.canvas.create_oval(25+30*x-12 , 25+30*y-12 , 25+30*x+12 , 25+30*y+12 , fill = self.color,tags = 'chessman') if self.game_win(y,x,self.color_count) : print(self.color,'獲勝') self.game_print.set(self.color+'獲勝') else : self.change_color() self.game_print.set('請'+self.color+'落子') #保證棋子落在棋盤上 def limit_boarder(self , y , x) : if x<0 or x>14 or y<0 or y>14 : return False else : return True #計算連子的數目,并返回最大連子數目 def chessman_count(self , y , x , color_count ) : count1,count2,count3,count4 = 1,1,1,1 #橫計算 for i in range(-1 , -5 , -1) : if self.db[y][x+i] == color_count : count1 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y][x+i] == color_count : count1 += 1 else: break #豎計算 for i in range(-1 , -5 , -1) : if self.db[y+i][x] == color_count : count2 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y+i][x] == color_count : count2 += 1 else: break #/計算 for i in range(-1 , -5 , -1) : if self.db[y+i][x+i] == color_count : count3 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y+i][x+i] == color_count : count3 += 1 else: break #計算 for i in range(-1 , -5 , -1) : if self.db[y+i][x-i] == color_count : count4 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y+i][x-i] == color_count : count4 += 1 else: break return max(count1 , count2 , count3 , count4) #判斷輸贏 def game_win(self , y , x , color_count ) : if self.chessman_count(y,x,color_count) >= 5 : self.flag_win = 1 self.flag_empty = 0 return True else : return False #悔棋,清空棋盤,再畫剩下的n-1個棋子 def withdraw(self ) : if len(self.order)==0 or self.flag_win == 1: return self.board.canvas.delete('chessman') z = self.order.pop() x = z%15 y = z//15 self.db[y][x] = 2 self.color_count = 1 for i in self.order : ix = i%15 iy = i//15 self.change_color() self.board.canvas.create_oval(25+30*ix-12 , 25+30*iy-12 , 25+30*ix+12 , 25+30*iy+12 , fill = self.color,tags = 'chessman') self.change_color() self.game_print.set('請'+self.color+'落子') #清空 def empty_all(self) : self.board.canvas.delete('chessman') #還原初始化 self.db = [([2] * 16) for i in range(16)] self.order = [] self.color_count = 0 self.color = ’black’ self.flag_win = 1 self.flag_empty = 1 self.game_print.set('') #將self.flag_win置0才能在棋盤上落子 def game_start(self) : #沒有清空棋子不能置0開始 if self.flag_empty == 0: return self.flag_win = 0 self.game_print.set('請'+self.color+'落子') def options(self) : self.board.canvas.bind('<Button-1>',self.chess_moving) Label(self.board.window , textvariable = self.game_print , font = ('Arial', 20) ).place(relx = 0, rely = 0 ,x = 495 , y = 200) Button(self.board.window , text= '開始游戲' ,command = self.game_start,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=15) Button(self.board.window , text= '我要悔棋' ,command = self.withdraw,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=60) Button(self.board.window , text= '清空棋局' ,command = self.empty_all,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=105) Button(self.board.window , text= '結束游戲' ,command = self.board.window.destroy,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=420) self.board.window.mainloop()

最后,main函數

if __name__ == '__main__': game = Gobang()

將以上的所有程序復制粘貼,即為完整的程序了,可以運行。

最后來一個完整程序,一個一個復制粘貼簡直不要太麻煩。

’’’@Auther : gaoxin@Date : 2019.01.01@Version : 1.0’’’from tkinter import *import math#定義棋盤類class chessBoard() : def __init__(self) : self.window = Tk() self.window.title('五子棋游戲') self.window.geometry('660x470') self.window.resizable(0,0) self.canvas=Canvas(self.window , bg='#EEE8AC' , width=470, height=470) self.paint_board() self.canvas.grid(row = 0 , column = 0) def paint_board(self) : for row in range(0,15) : if row == 0 or row == 14 : self.canvas.create_line(25 , 25+row*30 , 25+14*30 , 25+row*30 , width = 2) else : self.canvas.create_line(25 , 25+row*30 , 25+14*30 , 25+row*30 , width = 1) for column in range(0,15) : if column == 0 or column == 14 : self.canvas.create_line(25+column*30 ,25, 25+column*30 , 25+14*30 ,width = 2) else : self.canvas.create_line(25+column*30 ,25, 25+column*30 , 25+14*30 , width = 1) self.canvas.create_oval(112, 112, 118, 118, fill='black') self.canvas.create_oval(352, 112, 358, 118, fill='black') self.canvas.create_oval(112, 352, 118, 358, fill='black') self.canvas.create_oval(232, 232, 238, 238, fill='black') self.canvas.create_oval(352, 352, 358, 358, fill='black')#定義五子棋游戲類#0為黑子 , 1為白子 , 2為空位class Gobang() : #初始化 def __init__(self) : self.board = chessBoard() self.game_print = StringVar() self.game_print.set('') #16*16的二維列表,保證不會out of index self.db = [([2] * 16) for i in range(16)] #悔棋用的順序列表 self.order = [] #棋子顏色 self.color_count = 0 self.color = ’black’ #清空與贏的初始化,已贏為1,已清空為1 self.flag_win = 1 self.flag_empty = 1 self.options() #黑白互換 def change_color(self) : self.color_count = (self.color_count + 1 ) % 2 if self.color_count == 0 : self.color = 'black' elif self.color_count ==1 : self.color = 'white' #落子 def chess_moving(self ,event) : #不點擊“開始”與“清空”無法再次開始落子 if self.flag_win ==1 or self.flag_empty ==0 : return #坐標轉化為下標 x,y = event.x-25 , event.y-25 x = round(x/30) y = round(y/30) #點擊位置沒用落子,且沒有在棋盤線外,可以落子 while self.db[y][x] == 2 and self.limit_boarder(y,x): self.db[y][x] = self.color_count self.order.append(x+15*y) self.board.canvas.create_oval(25+30*x-12 , 25+30*y-12 , 25+30*x+12 , 25+30*y+12 , fill = self.color,tags = 'chessman') if self.game_win(y,x,self.color_count) : print(self.color,'獲勝') self.game_print.set(self.color+'獲勝') else : self.change_color() self.game_print.set('請'+self.color+'落子') #保證棋子落在棋盤上 def limit_boarder(self , y , x) : if x<0 or x>14 or y<0 or y>14 : return False else : return True #計算連子的數目,并返回最大連子數目 def chessman_count(self , y , x , color_count ) : count1,count2,count3,count4 = 1,1,1,1 #橫計算 for i in range(-1 , -5 , -1) : if self.db[y][x+i] == color_count : count1 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y][x+i] == color_count : count1 += 1 else: break #豎計算 for i in range(-1 , -5 , -1) : if self.db[y+i][x] == color_count : count2 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y+i][x] == color_count : count2 += 1 else: break #/計算 for i in range(-1 , -5 , -1) : if self.db[y+i][x+i] == color_count : count3 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y+i][x+i] == color_count : count3 += 1 else: break #計算 for i in range(-1 , -5 , -1) : if self.db[y+i][x-i] == color_count : count4 += 1 else: break for i in range(1 , 5 ,1 ) : if self.db[y+i][x-i] == color_count : count4 += 1 else: break return max(count1 , count2 , count3 , count4) #判斷輸贏 def game_win(self , y , x , color_count ) : if self.chessman_count(y,x,color_count) >= 5 : self.flag_win = 1 self.flag_empty = 0 return True else : return False #悔棋,清空棋盤,再畫剩下的n-1個棋子 def withdraw(self ) : if len(self.order)==0 or self.flag_win == 1: return self.board.canvas.delete('chessman') z = self.order.pop() x = z%15 y = z//15 self.db[y][x] = 2 self.color_count = 1 for i in self.order : ix = i%15 iy = i//15 self.change_color() self.board.canvas.create_oval(25+30*ix-12 , 25+30*iy-12 , 25+30*ix+12 , 25+30*iy+12 , fill = self.color,tags = 'chessman') self.change_color() self.game_print.set('請'+self.color+'落子') #清空 def empty_all(self) : self.board.canvas.delete('chessman') #還原初始化 self.db = [([2] * 16) for i in range(16)] self.order = [] self.color_count = 0 self.color = ’black’ self.flag_win = 1 self.flag_empty = 1 self.game_print.set('') #將self.flag_win置0才能在棋盤上落子 def game_start(self) : #沒有清空棋子不能置0開始 if self.flag_empty == 0: return self.flag_win = 0 self.game_print.set('請'+self.color+'落子') def options(self) : self.board.canvas.bind('<Button-1>',self.chess_moving) Label(self.board.window , textvariable = self.game_print , font = ('Arial', 20) ).place(relx = 0, rely = 0 ,x = 495 , y = 200) Button(self.board.window , text= '開始游戲' ,command = self.game_start,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=15) Button(self.board.window , text= '我要悔棋' ,command = self.withdraw,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=60) Button(self.board.window , text= '清空棋局' ,command = self.empty_all,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=105) Button(self.board.window , text= '結束游戲' ,command = self.board.window.destroy,width = 13, font = ('Verdana', 12)).place(relx=0, rely=0, x=495, y=420) self.board.window.mainloop() if __name__ == '__main__': game = Gobang()

更多有趣的經典小游戲實現專題,分享給大家:

C++經典小游戲匯總

python經典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經典游戲 玩不停

javascript經典小游戲匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美专区一区二区三区| 日韩在线观看中文字幕| 国产精品美女在线观看直播| 国产精品xxx在线观看| 久久精品理论片| 久久久精品午夜少妇| 亚洲综合不卡| 国产精品一区二区三区av麻| 国产不卡精品| 中文精品电影| 麻豆精品国产91久久久久久| 亚洲v在线看| 亚洲啊v在线免费视频| 卡一卡二国产精品| 欧美在线影院| 国产精品xxx在线观看| 另类中文字幕国产精品| 影音先锋久久精品| 成午夜精品一区二区三区软件| 亚洲精选久久| 精品视频一区二区三区在线观看| 日韩精品一区二区三区av| 国产伊人久久| 中文字幕一区二区精品区| 久久gogo国模啪啪裸体| 好看的av在线不卡观看| 久久不卡国产精品一区二区| 亚洲国产成人二区| 亚洲综合日本| 成人在线免费观看91| 日韩精品一级二级| av一区在线| 你懂的国产精品| 日韩专区在线视频| 日韩激情一区| 国产麻豆精品久久| 国产亚洲福利| 美女网站视频一区| 国产精品久久777777毛茸茸| 蜜桃久久久久久| 欧洲亚洲一区二区三区| 国产精品一区毛片| 免费人成在线不卡| 国产一区二区三区自拍| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 国产日韩一区二区三免费高清 | 一区视频在线| 裤袜国产欧美精品一区| 日韩精品一区二区三区中文字幕| 中文字幕av一区二区三区人| 中文一区一区三区高中清不卡免费| 在线手机中文字幕| 青青草国产精品亚洲专区无| 欧美在线影院| 欧美三级精品| 四虎成人av| 久久不见久久见国语| 91九色综合| 中文字幕亚洲影视| 香蕉精品999视频一区二区| 欧美黄色网页| 精品国产18久久久久久二百| 国产精品三p一区二区| 91精品国产一区二区在线观看 | 91精品啪在线观看国产18| 日韩理论视频| 美女福利一区二区三区| 97人人精品| 国产精品yjizz视频网| 国产中文欧美日韩在线| 国产精品久av福利在线观看| 国产精东传媒成人av电影| 91成人福利| 久久国产麻豆精品| 国产欧美日韩一区二区三区四区| 91精品亚洲| 99视频精品全部免费在线视频| 亚洲精品看片| 亚洲综合婷婷| 一区二区三区网站| 日本国产欧美| 国产精品一区二区三区www| 国产精品成人一区二区网站软件| 99视频+国产日韩欧美| 午夜精品一区二区三区国产| 亚洲大全视频| 91久久久精品国产| 不卡在线一区二区| 中文国产一区| 日韩欧乱色一区二区三区在线| 日韩激情一区| 婷婷中文字幕一区| 亚洲综合激情在线| 国产精品115| 国内精品麻豆美女在线播放视频| 日韩中文字幕视频网| 欧美日韩一区自拍| 麻豆精品99| 91精品xxx在线观看| 亚洲黄页一区| 免费高清在线一区| 国产精品一区二区精品视频观看 | 亚洲成人二区| 中文一区一区三区免费在线观 | 日本精品在线中文字幕| 亚洲国产成人精品女人| 亚洲欧洲国产精品一区| 国产精品一区二区精品视频观看 | 日韩欧美中文字幕电影| 免费亚洲婷婷| 欧美一级鲁丝片| 国产精品日韩久久久| 亚洲欧洲美洲国产香蕉| 毛片不卡一区二区| 日韩久久精品网| 中文亚洲免费| 国产日韩欧美一区二区三区在线观看| 免费美女久久99| 国产精品成人国产| 欧美日韩一二| 欧美一级一区| www.九色在线| 亚洲精品字幕| 女生影院久久| 日韩中文字幕在线一区| www.九色在线| 亚洲精品黄色| 国产在线|日韩| 欧美一级二级三级视频| 欧美特黄一级大片| 国产精品久一| 久久www成人_看片免费不卡| 精品一区二区三区中文字幕视频 | 午夜亚洲福利| 伊人久久av| 日韩国产成人精品| 激情综合自拍| 免费亚洲婷婷| 中文字幕一区二区三区四区久久| 久久av在线| 久久电影tv| 日韩一区二区三免费高清在线观看 | 美女精品一区| 日韩欧美自拍| 国产精品久久久一区二区| 国产91一区| 欧美激情福利| 亚洲综合色婷婷在线观看| 亲子伦视频一区二区三区| 欧美日韩xxxx| 免费国产亚洲视频| 九一精品国产| 亚洲国产福利| 国产精品xxx| 日韩精品一区二区三区中文在线| 国产劲爆久久| 亚洲精品第一| 久久亚洲国产精品一区二区| 欧美中文一区二区| 国产精品久久久久久久久妇女| 视频福利一区| 久久精品色播| 欧美日韩一区二区国产| 视频在线观看一区| 午夜免费一区| 性欧美xxxx免费岛国不卡电影| 亚洲精品日本| 亚洲综合日本| 亚洲激情久久| 性欧美69xoxoxoxo| 福利一区视频| 精品国产乱码| 国产高清亚洲| 国产精品亚洲四区在线观看| 亚洲精品欧美| 亚洲精品极品| 男女男精品视频网| 中文国产一区| 欧美国产视频| 国产精品精品| 精品国产美女a久久9999| 国产精品伦一区二区| 伊人www22综合色| 亚洲一区二区三区四区五区午夜| 视频一区日韩精品| 蜜臀久久99精品久久久画质超高清 | 麻豆精品视频在线观看视频| 国产探花在线精品| 日本综合精品一区| 日本一区福利在线| 日韩激情一区二区| 国产免费久久| 国产福利一区二区三区在线播放| 午夜久久免费观看| 亚洲少妇在线| 久久成人一区| 亚洲精品国产日韩| 国产精品密蕾丝视频下载| 久久99蜜桃| 国产成人免费|