iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >如何使用Python实现多路径迷宫
  • 637
分享到

如何使用Python实现多路径迷宫

2023-06-14 22:06:35 637人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

小编给大家分享一下如何使用python实现多路径迷宫,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Python的数据类型有哪些?python的数据类型:1. 数字

小编给大家分享一下如何使用python实现多路径迷宫,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

Python的数据类型有哪些?

python的数据类型:1. 数字类型,包括int(整型)、long(长整型)和float(浮点型)。2.字符串,分别是str类型和unicode类型。3.布尔型,Python布尔类型也是用于逻辑运算,有两个值:True(真)和False(假)。4.列表,列表是Python中使用最频繁的数据类型,集合中可以放任何数据类型。5. 元组,元组用”()”标识,内部元素用逗号隔开。6. 字典,字典是一种键值对的集合。7. 集合,集合是一个无序的、不重复的数据组合。

一、思路介绍

  • 在已有的单路径迷宫基础上打开一块合适的墙就可以构成2路径的迷宫。

  • 打开的墙不能和已有的路径过近。

  • 1。从开始和终点开始进行广度优先搜索,并为迷宫中的每个单元格记录单元格远离开始和终点的步数。

  • 2。通过将距离开头较近的所有单元格放入 start 集合,并将更接近目标的所有单元格放入end集合来将迷宫分成两个部分。

  • 3。 选择分开两个区域的任意一面墙拆开就可以形成2通路的迷宫。

  • 如想生成最短的通路可以选择相邻格子距离差值最大的那面墙拆开,一般情况下这两条路距离也比较远。

二、图示

如何使用Python实现多路径迷宫

三、分区域演示代码

#!/usr/bin/python3.7# -*- coding: utf-8 -*-import randomimport pygame#import depth_mazeimport maze#import aldous_broder_mazepygame.init()  # 初始化pygamesize = width, height = 800, 600  # 设置窗口大小screen = pygame.display.set_mode(size)  # 显示窗口# 颜色diamond_color_size = 8COLOR_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 = 20DIAMOND_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 c<cols-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 r<rows-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 nextListdef 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 algorithmdef 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 c<cols-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 r<rows-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 c<cols-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 r<rows-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 c<cols-1 and NOWALL == walls[r][c+1][0] and nl == grids[r][c+1] :                # move='r'                nr=r                nc=c+1            if r<rows-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 # mainif __name__ == "__main__":    '''main'''    multipath_maze_demo(20, 30)

以上是“如何使用Python实现多路径迷宫”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网Python频道!

--结束END--

本文标题: 如何使用Python实现多路径迷宫

本文链接: https://www.lsjlt.com/news/275540.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用Python实现多路径迷宫
    小编给大家分享一下如何使用Python实现多路径迷宫,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!python的数据类型有哪些python的数据类型:1. 数字类...
    99+
    2023-06-14
  • 教你怎么用Python实现多路径迷宫
    目录一、思路介绍二、图示三、分区域演示代码一、思路介绍 在已有的单路径迷宫基础上打开一块合适的墙就可以构成2路径的迷宫。 打开的墙不能和已有的路径过近。 1...
    99+
    2024-04-02
  • Python实现迷宫自动寻路实例
    目录背景预处理寻路算法测试优化绘制路径结语背景 我打开手机,发现有人在QQ空间里叫嚣。 看他得意的样子,显然是在家里呆久了,已经忘了天有多高。 预处理 设计一个迷宫自动寻路算法并不...
    99+
    2024-04-02
  • Python如何实现迷宫生成器
    这篇文章主要介绍了Python如何实现迷宫生成器的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python如何实现迷宫生成器文章都会有所收获,下面我们一起来看看吧。首先展示一下效果图:我们先分析一下所需的库:既...
    99+
    2023-07-02
  • Python如何实现过迷宫小游戏
    小编给大家分享一下Python如何实现过迷宫小游戏,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!开发工具Python版本: 3.6.4相关模块:pygame模块;以及一些Python自带的模块。环境搭建安装Python并添...
    99+
    2023-06-22
  • 如何使用python求解迷宫问题
    这篇文章主要介绍“如何使用python求解迷宫问题”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用python求解迷宫问题”文章能帮助大家解决问题。前言在迷宫问题中,给定入口和出口,要求找到路...
    99+
    2023-06-29
  • C++ DFS算法如何实现走迷宫自动寻路
    小编给大家分享一下C++ DFS算法如何实现走迷宫自动寻路,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!C++ DFS算法实现走迷宫自动寻路,供大家参考,具体内容...
    99+
    2023-06-15
  • 如何利用JAVA实现走迷宫程序
    本Demo使用三个类 一个Test类 一个自定义的Stack类 一个自定义的Queue类 可以实现的功能: 1.对于一个写在文本文件中的迷宫,能够将其转换为二维数组用广度优先搜索实现...
    99+
    2024-04-02
  • 如何实现一个canvas迷宫游戏
    小编给大家分享一下如何实现一个canvas迷宫游戏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!正文实现这个小游戏也不难,让我们想想,一个迷宫游戏有哪些基本要素。...
    99+
    2023-06-09
  • 使用python求解迷宫问题的三种实现方法
    目录前言递归求解回溯求解队列求解总结前言 在迷宫问题中,给定入口和出口,要求找到路径。本文将讨论三种求解方法,递归求解、回溯求解和队列求解。 在介绍具体算法之前,先考虑将迷宫数字化。...
    99+
    2024-04-02
  • 使用OpenCV实现迷宫解密的全过程
    目录一、你能自己走出迷宫吗?二、使用OpenCV找出出口。1、对图像进行二值化处理。2、 对二值化后的图像进行轮廓检测并标注3、对图像阈值进行处理。4、对图像进行扩展操作。...
    99+
    2024-04-02
  • 如何用Python进行编程迷宫大阵
    如何用Python进行编程迷宫大阵,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。前言由外国人编写的freegames是一个免费的开源游戏集合,这个很方便了我们的开发简单的游戏,...
    99+
    2023-06-02
  • Java如何实现经典游戏复杂迷宫
    这篇文章主要为大家展示了“Java如何实现经典游戏复杂迷宫”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java如何实现经典游戏复杂迷宫”这篇文章吧。前言人类建造迷宫已有5000年的历史。在世界...
    99+
    2023-06-29
  • 详解如何利用Python绘制迷宫小游戏
    目录构思绘制迷宫走出迷宫完整代码更大的挑战关于坐标系设置周末在家,儿子闹着要玩游戏,让玩吧,不利于健康,不让玩吧,扛不住他折腾,于是想,不如一起搞个小游戏玩玩! 之前给他编过猜数字 ...
    99+
    2024-04-02
  • 如何在Python中使用路径API实现并发编程?
    Python是一门流行的编程语言,被广泛应用于各种领域。在并发编程中,路径API是一个非常有用的工具,可以方便地操作文件和目录。本文将介绍如何在Python中使用路径API实现并发编程。 首先,我们需要了解一些基本的路径API。Python...
    99+
    2023-06-29
    并发 path api
  • 如何利用 Python 和 Apache 实现路径同步?
    在现代的软件开发和运维中,我们经常需要在不同的机器或者不同的环境中同步文件和目录。在这个过程中,我们需要找到一个高效、可靠、易于管理的路径同步方案。本文将介绍如何利用 Python 和 Apache 实现路径同步,让你的工作更加高效。 一...
    99+
    2023-09-29
    apache path 同步
  • Python 和 Apache 如何实现路径同步?
    在软件开发中,经常会遇到需要将本地文件同步到服务器上的情况。Python 和 Apache 都提供了一些工具和技术来帮助实现路径同步。本文将介绍如何使用 Python 和 Apache 实现路径同步。 一、使用 Python 实现路径同步...
    99+
    2023-09-29
    apache path 同步
  • 如何使用数据结构写个Html5走迷宫游戏
    这篇文章主要为大家展示了“如何使用数据结构写个Html5走迷宫游戏”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用数据结构写个Html5走迷宫游戏”这篇文...
    99+
    2024-04-02
  • AJAX如何实现跳转路径
    这篇文章主要为大家展示了“AJAX如何实现跳转路径”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“AJAX如何实现跳转路径”这篇文章吧。 ...
    99+
    2024-04-02
  • 在Python中,如何使用路径API实现高效的并发编程?
    在Python中,使用路径API实现高效的并发编程是一个非常重要的话题。在本文中,我们将讨论如何使用Python的路径API实现高效的并发编程,以及一些实用的技巧和技术。 首先,让我们了解一下Python的路径API。Python的路径AP...
    99+
    2023-06-29
    并发 path api
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作