python深度优先遍历解迷宫问题

这篇文章主要给大家介绍了关于python迷宫问题深度优先遍历的相关资料,深度优先搜索算法(Depth-First-Search),是搜索算法的一种,需要的朋友可以参考下

一、迷宫介绍

用python解迷宫问题,迷宫是一个二维列表,本次用深度优先解开迷宫问题。定义起点和终点,从一个位置到下一个位置只能通过向上或下或左或右,走一步来实现,从起点出发,如何找到一条到达终点的通路。

二、深度优先遍历

简单那我们的案例来讲就是,随便选择一条路,一直走,走不动了,再回头重新选择新的路

# 1 为墙,0 为路
maze = [
   [1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
   [1, 0, 1, 1, 0, 0, 0, 1, 1, 1],
   [1, 0, 1, 1, 1, 1, 0, 0, 1, 1],
   [1, 0, 1, 0, 0, 0, 0, 0, 1, 1],
   [1, 0, 1, 0, 1, 1, 1, 1, 1, 1],
   [1, 0, 0, 0, 1, 1, 1, 1, 1, 1],
   [1, 1, 1, 0, 0, 0, 0, 1, 1, 1],
   [1, 1, 1, 0, 0, 1, 0, 1, 1, 1],
   [1, 1, 1, 1, 1, 1, 0, 0, 0, 1],
   [1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
]

首先我们先设置一个起点和终点

start = (1, 1)
end = (8, 8)

判断当前这个点,0就是路可以走,1为墙不能走

对于一个点的下一个点的坐标准说明:

  • 上走:r – 1, c
  • 下走:r + 1, c
  • 左走:r, c – 1
  • 右走:r, c + 1

那我们这个迷宫的某个一个点达到了不能走的地步了,就是死胡同了,它就得原路返回

这时我们就有一个概念,就是栈,栈的思想就是:先进后出

怎么理解呢,可以举一个小例子,就是食堂阿姨,每天早上蒸包子,他是一层一层放蒸笼 那放到最后,学生来吃包子,她是从上往往外拿,最上面就是最后放的,最下面是最先放的,所以就叫做先进后出

其实list就是一个栈,比如我们放一个空列表,然后我们用这个列表直接append

再用pop进行取出,就会取到append的最后一个元素

# 定义列表,列表里面放的就是每一步走的坐标,[r, c]# 第一步就是起始位置,也就是start
list01 = [start]

走过的路定义为2

row, col = now
# python 里的解构也叫解包 now包括两个位置,一个行,一个列
maze[row][col] = 2
# 这个代表就是走过的点,为2,因为你走过的路是不能再走的,除了走不通返回的时候,也是为了走不通按原来走过的路原路返回

核心代码:

if maze[row - 1][col] == 0:
   # 上方可以走
   list01.append((row - 1, col))
   continueelif maze[row][col + 1] == 0:
   # 右方可以走
   list01.append((row, col + 1))
   continueelif maze[row + 1][col] == 0:
   # 下方可以走
   list01.append((row + 1, col))
   continueelif maze[row][col - 1] == 0:
   # 左方可以走
   list01.append((row, col - 1))
   continue

最终代码,可以运行一下试试:

maze = [
   [1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
   [1, 0, 1, 1, 0, 0, 0, 1, 1, 1],
   [1, 0, 1, 1, 1, 1, 0, 0, 1, 1],
   [1, 0, 1, 0, 0, 0, 0, 0, 1, 1],
   [1, 0, 1, 0, 1, 1, 1, 1, 1, 1],
   [1, 0, 0, 0, 1, 1, 1, 1, 1, 1],
   [1, 1, 1, 0, 0, 0, 0, 1, 1, 1],
   [1, 1, 1, 0, 0, 1, 0, 1, 1, 1],
   [1, 1, 1, 1, 1, 1, 0, 0, 0, 1],
   [1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
]

start = (1, 1)
end = (8, 8)

# 定义列表,列表里面放的就是每一步走的坐标,[r, c]# 第一步就是起始位置,也就是start
list01 = [start]

# 定义循环,让它走# 列表里最后存的就是下一步走的地方,当前列表有东西才能继续走while list01:
   # 当前走到的节点是哪一个节点,也就是最后走的一步,是哪一步,去列表的最后的一个值就是索引-1
   now = list01[-1]
   if now == end:  # 如果现在的now等于我们之前定义的终点end
       print(list01)
       print("出来了")
       break
   row, col = now
   # python 里的解构也叫解包 now包括两个位置,一个行,一个列
   maze[row][col] = 2
   # 这个代表就是走过的点,为2,因为你走过的路是不能再走的,除了走不通返回的时候,也就是为了走不通按原来走过的路原路返回

   # continue 结束本次循环,从新开始判断走路
   if maze[row - 1][col] == 0:
       # 上方可以走
       list01.append((row - 1, col))
       continue
   elif maze[row][col + 1] == 0:
       # 右方可以走
       list01.append((row, col + 1))
       continue
   elif maze[row + 1][col] == 0:
       # 下方可以走
       list01.append((row + 1, col))
       continue
   elif maze[row][col - 1] == 0:
       # 左方可以走
       list01.append((row, col - 1))
       continue
   else# 走不通过,直接循环干掉每一步,重新调整路线
       list01.pop()

else:
   print("这个迷宫走不通")

总结

到此这篇关于python迷宫问题深度优先遍历的文章就介绍到这了。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/222398.html<

(0)
运维的头像运维
上一篇2025-04-15 11:45
下一篇 2025-04-15 11:46

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注