亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1657 | 回復(fù): 0
打印 上一主題 下一主題

2048的python實(shí)現(xiàn)(基于OSC網(wǎng)友的代碼修改) [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2015-07-07 09:57 |只看該作者 |倒序?yàn)g覽
2048的python實(shí)現(xiàn)。解決了原網(wǎng)友版本的兩個(gè)小bug:
1. 原版游戲每次只消除一次,而不是遞歸消除。如 [2 ,2 ,2 ,2] 左移動(dòng)的話應(yīng)該是 [4, 4, 0, 0] , 而不是[8 , 0 , 0 ,0]
2. 對游戲結(jié)束的偵測有bug,已經(jīng)改正。

原網(wǎng)友版本:http://www.oschina.net/code/snippet_1756807_35638
我的實(shí)現(xiàn)版本:http://my.oschina.net/u/923087/blog/286050

2048game.py
  1. # -*- coding: utf-8 -*-
  2. """
  3. Created on Tue Jul  1 14:15:39 2014

  4. @author: kelvin
  5. """

  6. import random

  7. class game2048:
  8.     totalScore = 0
  9.     v = [[2, 8, 8, 2],
  10.          [4, 2, 4, 8],
  11.          [2, 4, 2, 0],
  12.          [4, 2, 4, 0]]
  13.     '''
  14.     v = [[0, 0, 0, 0],
  15.          [0, 0, 0, 0],
  16.          [0, 0, 0, 0],
  17.          [0, 0, 0, 0]]
  18.     '''
  19.     def __init__(self):
  20.         for i in range(4):
  21.             self.v[i] = [random.choice([0,0,0,2,2,4]) for x in range(4)]


  22.     def display(self):
  23.         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]))
  24.         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]))
  25.         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]))
  26.         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]))
  27.         print('得分為:{0:4}'.format(self.totalScore))
  28.         print('游戲是否結(jié)束:{0:4}'.format(self.isOver()))
  29.     #重新排列
  30.     def align(self,vList, direction):
  31.         for i in range(vList.count(0)):
  32.             vList.remove(0)
  33.         zeros = [0 for x in range(4-len(vList))]
  34.         if direction == 'left':
  35.             vList.extend(zeros)
  36.         else:
  37.             vList[:0] = zeros
  38.     #將相同的元素相加,返回新增積分
  39.     def addSame(self,vList, direction):
  40.         increment=0
  41.         if direction == 'left':
  42.             for i in [0,1,2]:
  43.                 if vList[i]==vList[i+1] and vList[i+1]!=0:
  44.                     vList[i] *= 2
  45.                     vList[i+1] = 0
  46.                     increment += vList[i]
  47.         else:
  48.             for i in [3,2,1]:
  49.                 if vList[i]==vList[i-1] and vList[i-1]!=0:
  50.                     vList[i] *= 2
  51.                     vList[i-1] = 0
  52.                     increment += vList[i]
  53.         return increment
  54.     #處理行和方向,返回新增積分
  55.     def handle(self, vList, direction):
  56.         self.align(vList, direction)
  57.         increment = self.addSame(vList, direction)
  58.         self.align(vList, direction)
  59.         self.totalScore += increment #直接加到總值
  60.         return increment
  61.     #判斷游戲是否結(jié)束
  62.     def judge(self):
  63.          
  64.         if self.isOver():
  65.             print('你輸了,游戲結(jié)束!')
  66.             return False
  67.         else:
  68.             if self.totalScore >= 2048:
  69.                 print('你贏了,游戲結(jié)束!但是你還可以繼續(xù)玩。')
  70.             return True
  71.     #判斷游戲是否真正結(jié)束
  72.     def isOver(self):
  73.         N = self.calcCharNumber(0)
  74.         if N!=0:
  75.             return False
  76.         else:
  77.             for row in range(4):
  78.                 flag = self.isListOver(self.v[row])
  79.                 if flag==False:
  80.                     return False   
  81.             for col in range(4):
  82.                 # 將矩陣中一列復(fù)制到一個(gè)列表中然后處理
  83.                 vList = [self.v[row][col] for row in range(4)]
  84.                 flag = self.isListOver(vList)
  85.                 if flag==False:
  86.                     return False
  87.         return True
  88.      
  89.     #判斷一個(gè)列表是否還可以合并
  90.     def isListOver(self, vList):
  91.         for i in [0,1,2]:
  92.             if vList[i]==vList[i+1] and vList[i+1]!=0:
  93.                 return False
  94.         return True
  95.     def calcCharNumber(self, char):
  96.         n = 0
  97.         for q in self.v:
  98.             n += q.count(char)
  99.         return n
  100.     def addElement(self):
  101.         # 統(tǒng)計(jì)空白區(qū)域數(shù)目 N
  102.         N = self.calcCharNumber(0)
  103.         if N!=0:
  104.             # 按2和4出現(xiàn)的幾率為3/1來產(chǎn)生隨機(jī)數(shù)2和4
  105.             num = random.choice([2, 2, 2, 4])
  106.             # 產(chǎn)生隨機(jī)數(shù)k,上一步產(chǎn)生的2或4將被填到第k個(gè)空白區(qū)域
  107.             k = random.randrange(1, N+1)    #k的范圍為[1,N]
  108.             n = 0
  109.             for i in range(4):
  110.                 for j in range(4):
  111.                     if self.v[i][j] == 0:
  112.                         n += 1
  113.                         if n == k:
  114.                             self.v[i][j] = num
  115.                             return

  116.                  
  117.     def moveLeft(self):
  118.         self.moveHorizontal('left')
  119.     def moveRight(self):
  120.         self.moveHorizontal('right')
  121.     def moveHorizontal(self, direction):
  122.         for row in range(4):
  123.             self.handle(self.v[row], direction)

  124.     def moveUp(self):
  125.         self.moveVertical('left')
  126.     def moveDown(self):
  127.         self.moveVertical('right')
  128.     def moveVertical(self, direction):
  129.         for col in range(4):
  130.             # 將矩陣中一列復(fù)制到一個(gè)列表中然后處理
  131.             vList = [self.v[row][col] for row in range(4)]
  132.             self.handle(vList, direction)
  133.             # 從處理后的列表中的數(shù)字覆蓋原來矩陣中的值
  134.             for row in range(4):
  135.                 self.v[row][col] = vList[row]
  136.                  
  137.     #主要的處理函數(shù)
  138.     def operation(self):
  139.         op = input('operator:')
  140.         if op in ['a', 'A']:    # 向左移動(dòng)
  141.             self.moveLeft()
  142.             self.addElement()
  143.         elif op in ['d', 'D']:  # 向右移動(dòng)
  144.             self.moveRight()
  145.             self.addElement()
  146.         elif op in ['w', 'W']:  # 向上移動(dòng)
  147.             self.moveUp()
  148.             self.addElement()
  149.         elif op in ['s', 'S']:  # 向下移動(dòng)
  150.             self.moveDown()
  151.             self.addElement()
  152.         else:
  153.             print('錯(cuò)誤的輸入。請輸入 [W, S, A, D] 或者是其小寫')   
  154.    
  155. #開始
  156. print('輸入:W(上移) S(下移) A(左移) D(右移), press <CR>.')
  157. g =game2048()
  158. flag = True
  159. while True:
  160.     g.display()
  161.     flag = g.judge()
  162.     g.operation()
  163.     flag = g.judge()
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP