Python和数据结构学习 --- 2

Array2D实现好之后就是要来做一个程序了.

简单测程序 `生命游戏`,当然以前发过的,不过是使用SDL+C++写的.

现在直接使用Python写,代码如下.

这个主要是棋盘的设定.

class LifeGrid:
    DEAD_CELL = 0
    LIVE_CELL = 1
    
    def __init__(self,numRows,numCols):
        self._grid = Array2D(numRows,numCols)
        self.configure(list())
        
    def numRows(self):
        return self._grid.numRows()
    
    def numCols(self):
        return self._grid.numCols()
    
    def configure(self,coordList):
        for i in range(self.numRows()):
            for j in range(self.numCols()):
                self.clearCell(i,j)
                
        for coord in coordList:
            self.setCell(coord[0],coord[1])
        
    
    def isLiveCell(self,row,col):
        return self._grid[row,col] == LifeGrid.LIVE_CELL
        
    def clearCell(self,row,col):
        self._grid[row,col] = LifeGrid.DEAD_CELL


    def setCell(self,row,col):
        self._grid[row,col] = LifeGrid.LIVE_CELL
    
    def numLiveNeighbors(self,r,c):
        A00,A01,A02 = 0,0,0
        A10,A11,A12 = 0,0,0
        A20,A21,A22 = 0,0,0
        
        rows = self.numRows()
        cols = self.numCols()
        
        grid = self._grid
        
        if r-1 >= 0 and c-1 >= 0:            
            A00 = grid[r-1,c-1]
        if r-1 >= 0:            
            A01 = grid[r-1,c]
        if r-1 >= 0 and c+1 <= cols-1:            
            A02 = grid[r-1,c+1]
            
        if c-1 >= 0:            
            A10 = grid[r,c-1]
        if c+1 <= cols - 1:            
            A12 = grid[r,c+1]
            
        if r+1<= rows-1 and c-1>=0:            
            A20 = grid[r+1,c-1]
        if r+1<= rows-1:            
            A21 = grid[r+1,c]
        if r+1<= rows-1 and c+1 <= cols-1:            
            A22 = grid[r+1,c+1]
        
        return A00 + A01 + A02 + \
               A10 + A11 + A12 +\
               A20 + A21 + A22

这个是主函数.

INIT_CONFIG = [(1,1),(1,2),(2,2),(3,2)]
GRID_WIDTH = 5
GRID_HEIGHT = 5

NUM_GENS = 8

#from IPython.display import clear_output
import time,sys


def main():
    grid = LifeGrid(GRID_WIDTH,GRID_HEIGHT)
    grid.configure(INIT_CONFIG)
    
    draw(grid)    
    sys.stdout.flush()
    #clear_output()
    time.sleep(0.5)
        
    for i in range(NUM_GENS):
        
        print "Frame:",i
        
        evolve(grid)
        draw(grid)
        
        sys.stdout.flush()
        #clear_output()
        time.sleep(0.5)
        
        
        
def evolve(grid):
    liveCells = list()
    for i in range(grid.numRows()):
        for j in range(grid.numCols()):            
            neighbors = grid.numLiveNeighbors(i,j)
            #print (i,j),"=",neighbors
            if (neighbors == 2 and grid.isLiveCell(i,j)) or \
                (neighbors == 3):
                liveCells.append((i,j))
                
    grid.configure(liveCells)
    
def draw(grid):
    for r in range(grid.numRows()):
        for c in range(grid.numCols()):
            if grid.isLiveCell(r,c):
                print "@ ",
            else:
                print ". ",
        print 
    print

main()

结果如下.

当然了我这里是在IPython notebook中运行的.如果把clear_output()函数打开的话可以得到一个动画效果.

耶.

posted @ 2012-11-29 17:02  zhuangzhuang1988  阅读(434)  评论(0编辑  收藏  举报