中文字幕在线观看,亚洲а∨天堂久久精品9966,亚洲成a人片在线观看你懂的,亚洲av成人片无码网站,亚洲国产精品无码久久久五月天

Python實(shí)現(xiàn) 深度優(yōu)先算法生成迷宮

2018-07-20    來源:open-open

容器云強(qiáng)勢上線!快速搭建集群,上萬Linux鏡像隨意使用
    import random  
      
    #warning: x and y confusing  
      
    sx = 10  
    sy = 10  
    dfs = [[0 for col in range(sx)] for row in range(sy)]  
    maze = [[' ' for col in range(2*sx+1)] for row in range(2*sy+1)]  
    #1:up 2:down 3:left 4:right  
    operation = {1:(0,-1),2:(0,1),3:(-1,0),4:(1,0)}  
    direction = [1, 2, 3, 4]  
    stack = []  
      
    for i in range(2*sx+1):  
        if i%2 == 0:  
            for j in range(2*sx+1):  
                maze[i][j] = '#'  
    for i in range(2*sy+1):  
        if i%2 == 0:  
            for j in range(2*sy+1):  
                maze[j][i] = '#'  
      
    def show(graph):  
        for i in graph:  
            for j in i:  
                print j,  
            print  
      
    def showRouter(stack):  
        RGragh = [[0 for col in range(sx)] for row in range(sy)]  
        for (x, y) in stack:  
            RGragh[y][x] = 1  
        show(RGragh)  
        print  
      
    def generateMaze(start):  
        x, y = start  
        dfs[y][x] = 1  
        random.shuffle(direction)  
        for d in direction:  
            px, py = (x + y for x, y in zip(start, operation[d]))  
            if px < 0 or px >= sx or py < 0 or py >= sy:  
                pass  
            else:  
                if dfs[py][px] is not 1:  
                    mx = 2*x + 1  
                    my = 2*y + 1  
                    if d == 1:  
                        maze[my-1][mx] = ' '  
                    elif d == 2:  
                        maze[my+1][mx] = ' '  
                    elif d == 3:  
                        maze[my][mx-1] = ' '  
                    elif d == 4:  
                        maze[my][mx+1] = ' '  
                    generateMaze((px,py))  
      
    generateMaze((0,0))  
    show(dfs)  
    show(maze)  

標(biāo)簽:

版權(quán)申明:本站文章部分自網(wǎng)絡(luò),如有侵權(quán),請聯(lián)系:west999com@outlook.com
特別注意:本站所有轉(zhuǎn)載文章言論不代表本站觀點(diǎn)!
本站所提供的圖片等素材,版權(quán)歸原作者所有,如需使用,請與原作者聯(lián)系。

上一篇:php給圖片加水印的代碼

下一篇:php驗(yàn)證碼類