婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 教你怎么用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實現多路徑迷宮的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美三级午夜理伦三级中视频| 国产69精品一区二区亚洲孕妇| 亚洲aaa精品| 不卡一区中文字幕| 日本一区二区视频在线观看| 免费在线欧美视频| 欧美草草影院在线视频| 免费在线看成人av| 91精品国产综合久久久蜜臀图片 | 亚洲一区av在线| 99精品视频一区二区三区| 国产视频一区二区在线| 成人激情小说乱人伦| 国产精品免费视频观看| 91亚洲精华国产精华精华液| 亚洲狠狠丁香婷婷综合久久久| 久久亚洲精品国产精品紫薇| 美女网站色91| 国产精品热久久久久夜色精品三区| 99re免费视频精品全部| 天天影视网天天综合色在线播放| 精品久久久久久无| 一本久久综合亚洲鲁鲁五月天 | 欧美三级三级三级爽爽爽| 日韩av中文字幕一区二区三区| 精品国产制服丝袜高跟| 99国内精品久久| 久久精品国产在热久久| 自拍偷拍亚洲欧美日韩| 欧美不卡一区二区三区四区| 一本色道综合亚洲| 久久99久久久久久久久久久| 中文字幕中文乱码欧美一区二区| 欧美日韩国产经典色站一区二区三区| 国产精品香蕉一区二区三区| 亚洲免费看黄网站| 国产女主播一区| 日韩视频免费观看高清完整版在线观看| www.av亚洲| 韩国三级电影一区二区| 亚洲国产毛片aaaaa无费看 | 在线一区二区三区四区| 精品一区中文字幕| 一区二区三区精品视频| 国产亚洲va综合人人澡精品| 欧美老年两性高潮| 不卡的电影网站| 国产成人aaa| 激情久久五月天| 亚洲va国产天堂va久久en| 亚洲精品写真福利| 国产日韩v精品一区二区| 精品欧美一区二区三区精品久久| 欧美日韩在线电影| 成人一级片网址| 国产精品综合视频| 韩国视频一区二区| 免费在线观看日韩欧美| 亚洲va欧美va人人爽| 亚洲亚洲人成综合网络| 欧美国产日韩亚洲一区| 久久综合国产精品| 国产三级一区二区三区| 久久婷婷久久一区二区三区| 欧美精品一区二区三区很污很色的 | 日韩国产精品久久久久久亚洲| 一区二区三区精品视频| 一区二区理论电影在线观看| 夜夜揉揉日日人人青青一国产精品| 国产精品美女久久久久高潮 | 国产精品三级在线观看| 欧美mv日韩mv| 精品国产凹凸成av人导航| 精品乱码亚洲一区二区不卡| 久久久www成人免费无遮挡大片| 欧美高清dvd| 在线视频中文字幕一区二区| 欧美午夜精品一区| 91精品国产91久久久久久一区二区 | 午夜影院久久久| 日韩成人午夜精品| 国产麻豆精品一区二区| 国产精品77777竹菊影视小说| 国产黄色精品网站| 色综合中文字幕国产| 95精品视频在线| 91麻豆福利精品推荐| 欧美日本韩国一区二区三区视频| 这里只有精品99re| 久久免费精品国产久精品久久久久| 中文av字幕一区| 亚洲成人免费电影| 国产精品白丝jk白祙喷水网站| 色综合中文字幕| 日韩精品中文字幕一区| 国产亚洲欧美在线| 一区二区三区国产精品| 国产成人在线视频免费播放| 91麻豆国产福利精品| 国产午夜精品一区二区 | 成人激情免费视频| 欧美精品在线观看播放| 欧美激情一区二区三区在线| 伊人婷婷欧美激情| 精品在线观看视频| 欧美日韩三级在线| 欧美经典三级视频一区二区三区| 亚洲一二三四区| 成人亚洲一区二区一| 3d成人h动漫网站入口| 亚洲色图.com| 国产91在线看| 精品少妇一区二区三区免费观看 | 日韩毛片精品高清免费| 蜜臀av性久久久久蜜臀av麻豆| 一本色道综合亚洲| 中文字幕国产一区二区| 亚洲国产精品精华液网站| 成人高清视频在线| 久久久一区二区三区| 日韩不卡一二三区| 欧美在线视频不卡| 日本一区二区免费在线| 蜜臀久久久久久久| 成人午夜精品一区二区三区| 欧美精品在线一区二区| 亚洲美女屁股眼交| av电影天堂一区二区在线观看| 日韩欧美激情四射| 日本不卡123| 宅男噜噜噜66一区二区66| 一区二区三区国产精华| 成人激情动漫在线观看| 国产精品色一区二区三区| 国产成人精品免费看| 久久久久综合网| 国产白丝网站精品污在线入口| 欧美成人video| 久久99精品久久久久久动态图| 7777精品久久久大香线蕉| 99久久精品免费看国产免费软件| 精品国产乱码久久久久久牛牛| 青青草97国产精品免费观看| 欧美一区日韩一区| 久久99精品一区二区三区| 日韩欧美色综合| 国产综合久久久久久久久久久久| 欧美videos大乳护士334| 国内精品久久久久影院薰衣草| 日韩欧美中文字幕一区| 国内精品视频666| 国产精品区一区二区三| 成人黄色小视频| 亚洲欧美日韩在线| 欧美日韩国产乱码电影| 理论片日本一区| 久久久久青草大香线综合精品| 懂色中文一区二区在线播放| 成人av资源下载| 亚洲午夜成aⅴ人片| 欧美电影一区二区| 六月丁香婷婷久久| 欧美国产日韩一二三区| 欧美色综合网站| 久热成人在线视频| 久久久久99精品国产片| 色乱码一区二区三区88| 免费高清在线一区| 欧美国产国产综合| 欧美巨大另类极品videosbest| 国产一区二区成人久久免费影院| 日韩美女视频一区| 777久久久精品| 成人激情午夜影院| 天堂va蜜桃一区二区三区| 中文字幕精品在线不卡| 欧美午夜精品一区二区三区| 国产一区 二区| 午夜成人在线视频| 国产精品久久久久天堂| 欧美精品第一页| 97se狠狠狠综合亚洲狠狠| 日韩有码一区二区三区| 中文字幕一区二区三区视频| 欧美一区二区福利在线| 一本一道久久a久久精品| 国产一区视频网站| 亚洲高清在线视频| 国产精品看片你懂得| 欧美videos中文字幕| 欧美日韩中字一区| 91欧美激情一区二区三区成人| 狠狠色狠狠色综合| 日本成人在线电影网| 亚洲欧美综合色| 欧美日韩激情在线| 91网页版在线| 久久夜色精品国产噜噜av| 国产成人精品免费视频网站| 天天免费综合色|