python實(shí)現(xiàn)2048小游戲
2048的python實(shí)現(xiàn)。修改自某網(wǎng)友的代碼,解決了原網(wǎng)友版本的兩個(gè)小bug:
1. 原版游戲每次只消除一次,而不是遞歸消除。如 [2 ,2 ,2 ,2] 左移動(dòng)的話(huà)應(yīng)該是 [4, 4, 0, 0] , 而不是[8 , 0 , 0 ,0]
2. 對(duì)游戲結(jié)束的偵測(cè)有bug,已經(jīng)改正。
2048game.py
# -*- coding: utf-8 -*- """ Created on Tue Jul 1 14:15:39 2014 @author: kelvin """ import random class game2048: totalScore = 0 v = [[2, 8, 8, 2], [4, 2, 4, 8], [2, 4, 2, 0], [4, 2, 4, 0]] ''' v = [[0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]] ''' def __init__(self): for i in range(4): self.v[i] = [random.choice([0,0,0,2,2,4]) for x in range(4)] def display(self): print('{0:4} {1:4} {2:4} {3:4}'.format(self.v[0][0], self.v[0][1], self.v[0][2], self.v[0][3])) print('{0:4} {1:4} {2:4} {3:4}'.format(self.v[1][0], self.v[1][1], self.v[1][2], self.v[1][3])) print('{0:4} {1:4} {2:4} {3:4}'.format(self.v[2][0], self.v[2][1], self.v[2][2], self.v[2][3])) print('{0:4} {1:4} {2:4} {3:4}'.format(self.v[3][0], self.v[3][1], self.v[3][2], self.v[3][3])) print('得分為:{0:4}'.format(self.totalScore)) print('游戲是否結(jié)束:{0:4}'.format(self.isOver())) #重新排列 def align(self,vList, direction): for i in range(vList.count(0)): vList.remove(0) zeros = [0 for x in range(4-len(vList))] if direction == 'left': vList.extend(zeros) else: vList[:0] = zeros #將相同的元素相加,返回新增積分 def addSame(self,vList, direction): increment=0 if direction == 'left': for i in [0,1,2]: if vList[i]==vList[i+1] and vList[i+1]!=0: vList[i] *= 2 vList[i+1] = 0 increment += vList[i] else: for i in [3,2,1]: if vList[i]==vList[i-1] and vList[i-1]!=0: vList[i] *= 2 vList[i-1] = 0 increment += vList[i] return increment #處理行和方向,返回新增積分 def handle(self, vList, direction): self.align(vList, direction) increment = self.addSame(vList, direction) self.align(vList, direction) self.totalScore += increment #直接加到總值 return increment #判斷游戲是否結(jié)束 def judge(self): if self.isOver(): print('你輸了,游戲結(jié)束!') return False else: if self.totalScore >= 2048: print('你贏了,游戲結(jié)束!但是你還可以繼續(xù)玩。') return True #判斷游戲是否真正結(jié)束 def isOver(self): N = self.calcCharNumber(0) if N!=0: return False else: for row in range(4): flag = self.isListOver(self.v[row]) if flag==False: return False for col in range(4): # 將矩陣中一列復(fù)制到一個(gè)列表中然后處理 vList = [self.v[row][col] for row in range(4)] flag = self.isListOver(vList) if flag==False: return False return True #判斷一個(gè)列表是否還可以合并 def isListOver(self, vList): for i in [0,1,2]: if vList[i]==vList[i+1] and vList[i+1]!=0: return False return True def calcCharNumber(self, char): n = 0 for q in self.v: n += q.count(char) return n def addElement(self): # 統(tǒng)計(jì)空白區(qū)域數(shù)目 N N = self.calcCharNumber(0) if N!=0: # 按2和4出現(xiàn)的幾率為3/1來(lái)產(chǎn)生隨機(jī)數(shù)2和4 num = random.choice([2, 2, 2, 4]) # 產(chǎn)生隨機(jī)數(shù)k,上一步產(chǎn)生的2或4將被填到第k個(gè)空白區(qū)域 k = random.randrange(1, N+1) #k的范圍為[1,N] n = 0 for i in range(4): for j in range(4): if self.v[i][j] == 0: n += 1 if n == k: self.v[i][j] = num return def moveLeft(self): self.moveHorizontal('left') def moveRight(self): self.moveHorizontal('right') def moveHorizontal(self, direction): for row in range(4): self.handle(self.v[row], direction) def moveUp(self): self.moveVertical('left') def moveDown(self): self.moveVertical('right') def moveVertical(self, direction): for col in range(4): # 將矩陣中一列復(fù)制到一個(gè)列表中然后處理 vList = [self.v[row][col] for row in range(4)] self.handle(vList, direction) # 從處理后的列表中的數(shù)字覆蓋原來(lái)矩陣中的值 for row in range(4): self.v[row][col] = vList[row] #主要的處理函數(shù) def operation(self): op = input('operator:') if op in ['a', 'A']: # 向左移動(dòng) self.moveLeft() self.addElement() elif op in ['d', 'D']: # 向右移動(dòng) self.moveRight() self.addElement() elif op in ['w', 'W']: # 向上移動(dòng) self.moveUp() self.addElement() elif op in ['s', 'S']: # 向下移動(dòng) self.moveDown() self.addElement() else: print('錯(cuò)誤的輸入。請(qǐng)輸入 [W, S, A, D] 或者是其小寫(xiě)') #開(kāi)始 print('輸入:W(上移) S(下移) A(左移) D(右移), press <CR>.') g =game2048() flag = True while True: g.display() flag = g.judge() g.operation() flag = g.judge()
演示圖
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
相關(guān)文章
基于python,Matplotlib繪制函數(shù)的等高線(xiàn)與三維圖像
這篇文章主要介紹了基于python,Matplotlib繪制函數(shù)的等高線(xiàn)與三維圖像,函數(shù)的等高線(xiàn)及其三維圖像的可視化方法,下面一起來(lái)學(xué)習(xí)具體內(nèi)容吧,需要的小伙伴可以參考一下2022-01-01tf.nn.conv2d與tf.layers.conv2d的區(qū)別及說(shuō)明
這篇文章主要介紹了tf.nn.conv2d與tf.layers.conv2d的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02pytest利用request?fixture實(shí)現(xiàn)個(gè)性化測(cè)試需求詳解
這篇文章主要為大家詳細(xì)介紹了pytest如何利用request?fixture實(shí)現(xiàn)個(gè)性化測(cè)試需求,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-09-09Python?網(wǎng)易易盾滑塊驗(yàn)證功能的實(shí)現(xiàn)
這篇文章主要介紹了Python?網(wǎng)易易盾滑塊驗(yàn)證,主要是借助之前寫(xiě)阿里云盾滑塊和極驗(yàn)滑塊的經(jīng)驗(yàn)寫(xiě)的本文,通過(guò)使用selenium請(qǐng)求url,并觸發(fā)滑塊驗(yàn)證,需要的朋友可以參考下2022-05-05Python高級(jí)特性之切片迭代列表生成式及生成器詳解
這篇文章主要為大家介紹了Python高級(jí)特性之切片迭代列表生成式及生成器詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-10-10Django數(shù)據(jù)庫(kù)類(lèi)庫(kù)MySQLdb使用詳解
Django項(xiàng)目要操作數(shù)據(jù)庫(kù),首先要和數(shù)據(jù)庫(kù)建立連接,才能讓程序中的數(shù)據(jù)和數(shù)據(jù)庫(kù)關(guān)聯(lián)起來(lái)進(jìn)行數(shù)據(jù)的增刪改查操作。這篇文章主要介紹了Django數(shù)據(jù)庫(kù)類(lèi)庫(kù)MySQLdb使用詳解,感興趣的小伙伴們可以參考一下2019-04-04