亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 教你怎么用Python實現多路徑迷宮

教你怎么用Python實現多路徑迷宮

熱門標簽:外呼不封號系統 悟空智電銷機器人6 遼寧400電話辦理多少錢 蘇州電銷機器人十大排行榜 電信營業廳400電話申請 江蘇房產電銷機器人廠家 幫人做地圖標注收費算詐騙嗎 荊州云電銷機器人供應商 溫州旅游地圖標注

一、思路介紹

  • 在已有的單路徑迷宮基礎上打開一塊合適的墻就可以構成2路徑的迷宮。
  • 打開的墻不能和已有的路徑過近。
  • 1。從開始和終點開始進行廣度優先搜索,并為迷宮中的每個單元格記錄單元格遠離開始和終點的步數。
  • 2。通過將距離開頭較近的所有單元格放入 start 集合,并將更接近目標的所有單元格放入end集合來將迷宮分成兩個部分。
  • 3。 選擇分開兩個區域的任意一面墻拆開就可以形成2通路的迷宮。
  • 如想生成最短的通路可以選擇相鄰格子距離差值最大的那面墻拆開,一般情況下這兩條路距離也比較遠。

二、圖示

三、分區域演示代碼

#!/usr/bin/python3.7
# -*- coding: utf-8 -*-
import random
import pygame
#import depth_maze
import maze
#import aldous_broder_maze

pygame.init()  # 初始化pygame
size = width, height = 800, 600  # 設置窗口大小
screen = pygame.display.set_mode(size)  # 顯示窗口
# 顏色
diamond_color_size = 8
COLOR_RED, COLOR_BLUE, COLOR_GREEN, COLOR_YELLOW, COLOR_BLACK, COLOR_GREY, COLOR_GOLDEN, COLOR_NO_DIAMOND = list(range(
    diamond_color_size))
COLOR = {
    COLOR_RED: (255, 0, 0),
    COLOR_BLUE: (0, 0, 255),
    COLOR_GREEN: (0, 255, 0),
    COLOR_YELLOW: (255, 255, 0),
    COLOR_BLACK: (0, 0, 0),
    COLOR_GREY: (250, 240, 230),
    COLOR_GOLDEN : (255,215,0),
    COLOR_NO_DIAMOND: (100, 100, 100),
}
# 格子大小
DIAMOND_LEN = 20
DIAMOND_SIZE = (DIAMOND_LEN, DIAMOND_LEN)
# 藍格子
DIAMOND=pygame.surface.Surface(DIAMOND_SIZE).convert()
DIAMOND.fill(COLOR[COLOR_BLUE])
# 綠格子 
DIAMOND_GREEN=pygame.surface.Surface(DIAMOND_SIZE).convert()
DIAMOND_GREEN.fill(COLOR[COLOR_GREEN])
# 紅格子 
DIAMOND_RED=pygame.surface.Surface(DIAMOND_SIZE).convert()
DIAMOND_RED.fill(COLOR[COLOR_RED])
# 黃格子 
DIAMOND_YELLOW=pygame.surface.Surface(DIAMOND_SIZE).convert()
DIAMOND_YELLOW.fill(COLOR[COLOR_YELLOW])
# 灰的格子 
DIAMOND_GREY=pygame.surface.Surface(DIAMOND_SIZE).convert()
DIAMOND_GREY.fill(COLOR[COLOR_GREY])
# 字體
use_font = pygame.font.Font("FONT.TTF", 16)
use_font12 = pygame.font.Font("FONT.TTF", 12)
# 背景
background=pygame.surface.Surface(size).convert()
background.fill(COLOR[COLOR_BLACK])
# 文字
score_surface = use_font.render("找到終點", True, COLOR[COLOR_BLACK], COLOR[COLOR_GREY])
# 時間
clock = pygame.time.Clock()

##############################################
#   格子訪問標記x,y,0,右墻x,y,1,下墻x,y,2
##############################################
#標記 
NOWALL=maze.NOWALL # 無墻
WALL=maze.WALL  # 有墻
WALL2=maze.WALL2  # 有墻

VISIT=maze.VISIT # 到訪過
NOVISIT=maze.NOVISIT # 沒到過
VERTICAL = maze.VERTICAL # 垂直的
HORIZONTAL = maze.HORIZONTAL# 水平的
INFINITE = maze.INFINITE # 無窮遠

INFINITE = maze.INFINITE # 無窮遠

# 
def FindNext(pathList, walls, grids, rows, cols):
    nextList = [] # 下一步
    for node in pathList:
        r, c = node
        l = grids[r][c]
        nl=l+1
        # 可以到達的位置
        if r>0 and NOWALL == walls[r][c][1] and INFINITE == grids[r-1][c]:
            # move = 'u'
            nr=r-1
            nc=c
            if (nr,nc) not in nextList:
                nextList.append((nr,nc))
                grids[nr][nc] = l+1
        if c>0 and NOWALL == walls[r][c][0] and INFINITE == grids[r][c-1]:
            # move = 'l'
            nr=r
            nc=c-1
            if (nr,nc) not in nextList:
                nextList.append((nr,nc))
                grids[nr][nc] = l+1
        if ccols-1 and NOWALL == walls[r][c+1][0] and INFINITE == grids[r][c+1] :
            # move='r'
            nr=r
            nc=c+1
            if (nr,nc) not in nextList:
                nextList.append((nr,nc))
                grids[nr][nc] = l+1
        if rrows-1 and NOWALL == walls[r+1][c][1] and INFINITE == grids[r+1][c] :
            # move='d'
            nr=r+1
            nc=c
            if (nr,nc) not in nextList:
                nextList.append((nr,nc))
                grids[nr][nc] = l+1
    return nextList


def draw_diamond(r,c, screen, POSX, POSY, diamod):
    px,py=POSX + 1 + (c) * DIAMOND_SIZE[0], POSY + 1 + (r) * DIAMOND_SIZE[1]
    # 標記訪問過的格子
    screen.blit(diamod, (px, py))
    return 

def draw_diamond_and_str(r,c, screen, POSX, POSY, diamod, use_font, string, color, color_back):
    px,py=POSX + 1 + (c) * DIAMOND_SIZE[0], POSY + 1 + (r) * DIAMOND_SIZE[1]
    # 標記訪問過的格子
    screen.blit(diamod, (px, py))
    distance_surface = use_font.render(string, True, color, color_back)
    screen.blit(distance_surface, (px, py))
    return 


# Sample algorithm
def multipath_maze_demo(rows, cols):
    #walls = maze.aldous_broder_maze(rows, cols)
    #walls = maze.depth_maze(rows, cols)
    #walls = maze.kruskal_maze(rows, cols)
    #walls = maze.prim_maze(rows, cols)
    #walls = maze.wilson_maze(rows, cols)
    walls = maze.wilson_maze(rows, cols)
    POSX=40
    POSY=40
    # 初始化未訪問
    grids=[[ INFINITE for i in range(cols)]for j in range(rows)]
    # 起點
    # 標記迷宮
    r=0
    c=0
    findEndPoint=False
    findPath=False
    # 起點
    startPoint=(r,c)
    # 終點
    stopPoint=(rows-1,cols-1)
    # 
    mainList=[] # 主路徑

    beginList=[startPoint]
    endList=[stopPoint]
    grids[r][c]=0 # 標記已經到過格子距離
    grids[stopPoint[0]][stopPoint[1]]=0

    # 沒有訪問過的格子
    notUseGrids = [] 
    for tr in range(rows):
        for tc in range(cols):
            notUseGrids.append((tr,tc))

    beginMap=beginList
    endMap=endList

    while True:
        for event in pygame.event.get():
            if event.type == pygame.QUIT:
                return
        if notUseGrids:        
            beginNextList = [] # 下一步
            for node in beginList:
                r, c = node
                l = grids[r][c]
                # 可以到達的位置
                if r>0 and NOWALL == walls[r][c][1] and INFINITE == grids[r-1][c]:
                    # move = 'u'
                    nr=r-1
                    nc=c
                    if (nr,nc) not in beginNextList:
                        beginNextList.append((nr,nc))
                        grids[nr][nc] = l+1
                if c>0 and NOWALL == walls[r][c][0] and INFINITE == grids[r][c-1]:
                    # move = 'l'
                    nr=r
                    nc=c-1
                    if (nr,nc) not in beginNextList:
                        beginNextList.append((nr,nc))
                        grids[nr][nc] = l+1
                if ccols-1 and NOWALL == walls[r][c+1][0] and INFINITE == grids[r][c+1] :
                    # move='r'
                    nr=r
                    nc=c+1
                    if (nr,nc) not in beginNextList:
                        beginNextList.append((nr,nc))
                        grids[nr][nc] = l+1
                if rrows-1 and NOWALL == walls[r+1][c][1] and INFINITE == grids[r+1][c] :
                    # move='d'
                    nr=r+1
                    nc=c
                    if (nr,nc) not in beginNextList:
                        beginNextList.append((nr,nc))
                        grids[nr][nc] = l+1
            # 下一圈
            beginList = beginNextList
            beginMap = beginMap + beginNextList
            # end
            endNextList = [] # 下一步
            for node in endList:
                r, c = node
                l = grids[r][c]
                # 可以到達的位置
                if r>0 and NOWALL == walls[r][c][1] and INFINITE == grids[r-1][c]:
                    # move = 'u'
                    nr=r-1
                    nc=c
                    if (nr,nc) not in endNextList:
                        endNextList.append((nr,nc))
                        grids[nr][nc] = l+1
                if c>0 and NOWALL == walls[r][c][0] and INFINITE == grids[r][c-1]:
                    # move = 'l'
                    nr=r
                    nc=c-1
                    if (nr,nc) not in endNextList:
                        endNextList.append((nr,nc))
                        grids[nr][nc] = l+1
                if ccols-1 and NOWALL == walls[r][c+1][0] and INFINITE == grids[r][c+1] :
                    # move='r'
                    nr=r
                    nc=c+1
                    if (nr,nc) not in endNextList:
                        endNextList.append((nr,nc))
                        grids[nr][nc] = l+1
                if rrows-1 and NOWALL == walls[r+1][c][1] and INFINITE == grids[r+1][c] :
                    # move='d'
                    nr=r+1
                    nc=c
                    if (nr,nc) not in endNextList:
                        endNextList.append((nr,nc))
                        grids[nr][nc] = l+1
            # 下一圈
            endList = endNextList
            endMap = endMap + endNextList

        elif findEndPoint and not findPath:
            mainList.append((r,c))
            l = grids[r][c]
            nl=l-1
            # 最近的
            if r>0 and NOWALL == walls[r][c][1] and nl == grids[r-1][c]:
                # move = 'u'
                nr=r-1
                nc=c
            if c>0 and NOWALL == walls[r][c][0] and nl == grids[r][c-1]:
                # move = 'l'
                nr=r
                nc=c-1
                beginNextList.append((nr,nc))
            if ccols-1 and NOWALL == walls[r][c+1][0] and nl == grids[r][c+1] :
                # move='r'
                nr=r
                nc=c+1
            if rrows-1 and NOWALL == walls[r+1][c][1] and nl == grids[r+1][c] :
                # move='d'
                nr=r+1
                nc=c
            # 找到起點
            if 0 == nl:
                mainList.append((nr,nc))
                findPath = True
            r,c=nr,nc

        screen.blit(background, (0, 0))
        # 格子
        for cx in range(cols):
            for ry in range(rows):
                px,py=POSX + 1 + (cx) * DIAMOND_SIZE[0], POSY + 1 + (ry) * DIAMOND_SIZE[1]
                # 標記訪問過的格子
                if maze.INFINITE == grids[ry][cx]:
                    draw_diamond(ry, cx, screen, POSX, POSY, DIAMOND)
                else:
                    s = "{}".format(grids[ry][cx])
                    draw_diamond_and_str(ry, cx, screen, POSX,POSY, DIAMOND_GREY, use_font12, s, COLOR[COLOR_BLACK], COLOR[COLOR_GREY]) 
        # 圈地
        for pos in beginMap:
            s = "{}".format(grids[pos[0]][pos[1]])
            draw_diamond_and_str(pos[0], pos[1], screen, POSX,POSY, DIAMOND_GREEN, use_font12, s, COLOR[COLOR_BLACK], COLOR[COLOR_GREEN])
        for pos in endMap:
            s = "{}".format(grids[pos[0]][pos[1]])
            draw_diamond_and_str(pos[0], pos[1], screen, POSX,POSY, DIAMOND_YELLOW, use_font12, s, COLOR[COLOR_BLACK], COLOR[COLOR_YELLOW])
        # 循環外圈
        if beginList and not mainList:
            for pos in beginList:
                s = "{}".format(grids[pos[0]][pos[1]])
                draw_diamond_and_str(pos[0], pos[1], screen, POSX,POSY, DIAMOND_RED, use_font12, s, COLOR[COLOR_BLACK], COLOR[COLOR_RED])
            for pos in endList:
                s = "{}".format(grids[pos[0]][pos[1]])
                draw_diamond_and_str(pos[0], pos[1], screen, POSX,POSY, DIAMOND_RED, use_font12, s, COLOR[COLOR_BLACK], COLOR[COLOR_RED])
        # 路徑
        if mainList:
            for pos in mainList:
                s = "{}".format(grids[pos[0]][pos[1]])
                draw_diamond_and_str(pos[0], pos[1], screen, POSX,POSY, DIAMOND_YELLOW, use_font12, s, COLOR[COLOR_BLACK], COLOR[COLOR_YELLOW])
            # r,c
            px,py=POSX + 1 + (c) * DIAMOND_SIZE[0], POSY + 1 + (r) * DIAMOND_SIZE[1]
            screen.blit(DIAMOND_GREEN, (px, py))
            s = "{}".format(grids[r][c])
            distance_surface = use_font12.render(s, True, COLOR[COLOR_BLACK], COLOR[COLOR_GREEN])
            screen.blit(distance_surface, (px, py))

        # 畫外墻
        pygame.draw.rect(screen, COLOR[COLOR_RED], (POSX + 0, POSY + 0, DIAMOND_LEN*cols+1, DIAMOND_LEN*rows+1), 2)
        # 畫沒打通的墻
        for cx in range( cols):
            for ry in range(rows):
                px,py=POSX + 1 + (cx) * DIAMOND_SIZE[0], POSY + 1 + (ry) * DIAMOND_SIZE[1]
                color = COLOR[COLOR_BLACK]
                if maze.WALL == walls[ry][cx][0]:
                    pygame.draw.line(screen, color, (px, py), (px, py+DIAMOND_LEN), 2)
                if maze.WALL == walls[ry][cx][1]:
                    pygame.draw.line(screen, color, (px, py), (px+DIAMOND_LEN, py), 2)
        # 打印文字提示
        if findEndPoint:
            screen.blit(score_surface, (POSX+50, POSY+rows*22))
        # 幀率
        clock.tick(25)

        pygame.display.update()
    return 



# main
if __name__ == "__main__":
    '''main'''
    multipath_maze_demo(20, 30)

到此這篇關于教你怎么用Python實現多路徑迷宮的文章就介紹到這了,更多相關Python實現多路徑迷宮內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 如何用 Python 制作一個迷宮游戲
  • Python 實現遞歸法解決迷宮問題的示例代碼
  • Python迷宮生成和迷宮破解算法實例
  • 10分鐘教你用python動畫演示深度優先算法搜尋逃出迷宮的路徑
  • Python解決走迷宮問題算法示例
  • 一道python走迷宮算法題
  • Python深度優先算法生成迷宮
  • Python使用Tkinter實現機器人走迷宮
  • Python基于分水嶺算法解決走迷宮游戲示例
  • Python使用回溯法子集樹模板解決迷宮問題示例
  • Python基于遞歸算法實現的走迷宮問題
  • 用Python代碼來解圖片迷宮的方法整理
  • python實現的生成隨機迷宮算法核心代碼分享(含游戲完整代碼)

標簽:宿遷 三沙 黃山 欽州 喀什 濟南 景德鎮 臺灣

巨人網絡通訊聲明:本文標題《教你怎么用Python實現多路徑迷宮》,本文關鍵詞  教你,怎么,用,Python,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《教你怎么用Python實現多路徑迷宮》相關的同類信息!
  • 本頁收集關于教你怎么用Python實現多路徑迷宮的相關信息資訊供網民參考!
  • 推薦文章
    欧美大片一区| 黄视频网站免费| 国产视频一区二区在线播放| 99色播| 九九九国产| 亚欧成人乱码一区二区| 天堂网中文在线| 国产视频久久久| 国产不卡在线看| 久久久久久久男人的天堂| 一级女性全黄久久生活片| 午夜在线影院| 韩国三级一区| 国产麻豆精品免费密入口| 精品国产三级a∨在线观看| 黄视频网站免费看| 一本高清在线| 九九九网站| 亚洲第一色在线| 色综合久久久久综合体桃花网| 欧美a级片免费看| 欧美爱色| 国产一区免费在线观看| 韩国毛片| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 色综合久久天天综合观看| 亚欧视频在线| 久久成人综合网| 一 级 黄 中国色 片| 国产欧美精品| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产一级强片在线观看| 国产综合成人观看在线| 可以免费看毛片的网站| 成人免费高清视频| 精品国产一区二区三区精东影业| 精品视频在线看 | 久久精品道一区二区三区| 日韩在线观看视频网站| 国产福利免费视频| 一级女性全黄生活片免费| 成人免费网站久久久| 精品国产亚洲一区二区三区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产精品自拍在线| 麻豆网站在线看| 国产a视频| 欧美一级视频免费| 精品视频在线观看视频免费视频| 日韩专区一区| 久久久久久久网| 日韩av成人| 国产成人啪精品| 精品久久久久久中文字幕一区| 91麻豆爱豆果冻天美星空| 可以免费看毛片的网站| 韩国毛片免费大片| 日本特黄特黄aaaaa大片| 韩国三级香港三级日本三级la | 久久久久久久男人的天堂| 91麻豆精品国产片在线观看| 国产原创视频在线| a级黄色毛片免费播放视频| 久久精品道一区二区三区| 成人免费观看视频| 一级毛片看真人在线视频| 国产美女在线一区二区三区| 亚洲爆爽| 国产精品免费精品自在线观看| 天天做日日爱夜夜爽| 沈樵在线观看福利| 国产一区二区精品| 九九久久99综合一区二区| 精品在线观看国产| 午夜在线亚洲| 欧美另类videosbestsex高清 | 成人免费一级纶理片| 精品视频在线观看免费| 午夜激情视频在线播放| 日韩在线观看免费| 欧美激情一区二区三区在线播放| 国产视频一区二区在线播放| 美女免费毛片| 欧美国产日韩一区二区三区| 青青久热| 国产一区二区精品| 黄视频网站免费看| 精品视频在线观看一区二区三区| 亚洲爆爽| 成人免费一级毛片在线播放视频| 国产成人精品综合在线| 99久久精品费精品国产一区二区| 久久99爰这里有精品国产| 国产91精品一区二区| 国产不卡在线观看视频| 黄色福利| 午夜家庭影院| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 成人影视在线观看| 国产一区二区精品| 久久精品欧美一区二区| 亚洲www美色| 成人av在线播放| 国产精品自拍在线观看| 欧美激情一区二区三区在线播放| 国产伦精品一区二区三区无广告| 日韩av成人| 欧美国产日韩一区二区三区| 日韩中文字幕一区| 999精品视频在线| 四虎久久影院| 亚洲天堂免费| 91麻豆国产福利精品| 国产高清在线精品一区二区| 欧美爱色| 99热精品在线| 国产一区精品| 久久99爰这里有精品国产| 可以在线看黄的网站| 九九干| 精品国产三级a∨在线观看| 精品国产亚一区二区三区| 欧美日本免费| 九九久久99综合一区二区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 九九精品久久| 中文字幕一区二区三区精彩视频| 黄视频网站在线免费观看| 欧美另类videosbestsex高清| 国产伦精品一区二区三区无广告| 99久久精品费精品国产一区二区| 99热视热频这里只有精品| 亚欧乱色一区二区三区| 韩国三级视频网站| 欧美激情在线精品video| 九九久久国产精品大片| 日本特黄一级| 精品久久久久久中文| 久久精品成人一区二区三区| 国产成人精品影视| 黄视频网站免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 一级女性全黄久久生活片| 午夜激情视频在线观看| 国产成+人+综合+亚洲不卡| 国产麻豆精品免费密入口| 日本伦理网站| 青草国产在线观看| 欧美激情一区二区三区视频| 美女免费毛片| 97视频免费在线观看| 国产美女在线观看| 国产一区免费在线观看| 香蕉视频久久| 久久成人综合网| 91麻豆国产| 久久99中文字幕久久| 久久精品大片| 国产视频一区二区在线观看| 久久精品店| 国产成人欧美一区二区三区的| 日本免费看视频| 一本高清在线| 午夜在线亚洲| 欧美另类videosbestsex久久 | 麻豆系列 在线视频| 欧美a级v片不卡在线观看| 欧美另类videosbestsex久久 | 日韩字幕在线| 青青久久国产成人免费网站| 成人影院一区二区三区| 欧美电影免费| 国产精品免费久久| 999精品影视在线观看| 999久久狠狠免费精品| 国产一区二区精品| 国产网站免费观看| 日韩中文字幕在线播放| 精品视频一区二区三区免费| 91麻豆高清国产在线播放| 久久99欧美| 亚洲wwwwww| 国产91素人搭讪系列天堂| 999精品在线| 久久精品免视看国产成人2021| 国产一区二区精品尤物| 国产不卡在线看| 欧美一级视频高清片| 亚洲女初尝黑人巨高清在线观看| 午夜在线影院| 日本在线播放一区| 亚飞与亚基在线观看| 国产伦精品一区三区视频| 欧美激情一区二区三区在线播放 | 999精品在线| 天天做人人爱夜夜爽2020毛片| 日韩免费在线| 久久精品店| 99久久精品国产国产毛片|