当前位置: 首页 > article >正文

Python迷宫寻路实战:用DFS和BFS分别找出所有路径和最短路径(附完整代码)

Python迷宫寻路实战深度优先与广度优先算法的本质差异迷宫寻路问题是理解算法思维的经典案例。第一次接触这个问题时我被同一个迷宫居然能找出多条路径的现象所吸引——这背后隐藏着两种截然不同的搜索策略深度优先搜索(DFS)和广度优先搜索(BFS)。让我们从实际代码出发看看这两种算法如何处理路径探索问题。1. 迷宫问题的算法基础1.1 问题建模与数据结构选择迷宫可以用二维数组表示其中0代表可通行路径1代表障碍物。对于5x5的迷宫maze [ [0, 1, 1, 1, 1], [0, 0, 0, 0, 1], [1, 1, 1, 0, 1], [1, 0, 0, 0, 1], [1, 0, 0, 0, 0] ]关键数据结构选择访问标记矩阵visited二维数组记录已探索位置路径记录path列表动态存储当前路径结果收集result列表保存最终路径方案1.2 算法选择的核心考量算法类型数据结构路径特性空间复杂度适用场景DFS栈/递归任意路径O(n)存在性判断BFS队列最短路径O(2^n)最优解搜索提示DFS更适合内存受限的大型迷宫而BFS保证找到最短路径但内存消耗更大2. 深度优先搜索的实践细节2.1 基础DFS实现递归实现的DFS最直观展现算法本质def dfs(maze, start, end, path, visited): x, y start if not (0 x len(maze) and 0 y len(maze[0])): return False if maze[x][y] 1 or visited[x][y]: return False visited[x][y] True path.append((x,y)) if start end: return True for dx, dy in [(1,0), (-1,0), (0,1), (0,-1)]: if dfs(maze, (xdx, ydy), end, path, visited): return True path.pop() return False关键操作解析访问标记进入新位置立即标记为已访问路径记录path.append()记录当前位置方向探索按固定顺序尝试四个方向回溯处理path.pop()撤销无效路径2.2 寻找所有路径的改进版通过修改回溯策略可以收集所有可行路径def dfs_all_paths(maze, start, end, path, visited, results): x, y start if not (0 x len(maze) and 0 y len(maze[0])): return if maze[x][y] 1 or visited[x][y]: return visited[x][y] True path.append((x,y)) if start end: results.append(path.copy()) else: for dx, dy in [(1,0), (-1,0), (0,1), (0,-1)]: dfs_all_paths(maze, (xdx, ydy), end, path, visited, results) visited[x][y] False path.pop()核心区别找到终点时不立即返回继续搜索回溯时重置访问标记visited[x][y] False使用path.copy()避免引用问题3. 广度优先搜索的层序遍历3.1 基础BFS实现使用队列实现层序遍历from collections import deque def bfs_shortest_path(maze, start, end): queue deque([(start, [start])]) visited set([start]) while queue: (x,y), path queue.popleft() for dx, dy in [(1,0), (-1,0), (0,1), (0,-1)]: nx, ny xdx, ydy if 0 nx len(maze) and 0 ny len(maze[0]): if maze[nx][ny] 0 and (nx,ny) not in visited: if (nx,ny) end: return path [(nx,ny)] visited.add((nx,ny)) queue.append(((nx,ny), path [(nx,ny)])) return None算法特性队列保证先进先出的探索顺序首次到达终点时路径必然最短需要额外存储路径信息3.2 路径重建优化更高效的方式是记录前驱节点def bfs_reconstruct_path(maze, start, end): queue deque([start]) visited {start: None} while queue: x,y queue.popleft() if (x,y) end: path [] while (x,y) ! start: path.append((x,y)) x,y visited[(x,y)] path.append(start) return path[::-1] for dx, dy in [(1,0), (-1,0), (0,1), (0,-1)]: nx, ny xdx, ydy if 0 nx len(maze) and 0 ny len(maze[0]): if maze[nx][ny] 0 and (nx,ny) not in visited: visited[(nx,ny)] (x,y) queue.append((nx,ny)) return None优势空间效率更高不存储完整路径回溯重建路径的时间成本可忽略4. 算法对比与实战建议4.1 性能实测对比对同一迷宫进行测试算法类型找到路径数执行时间(ms)内存使用(MB)DFS单路径12.11.8DFS全路径65.72.4BFS最短1(最短)3.53.14.2 调试技巧与常见问题DFS调试要点检查回溯时是否正确恢复现场确认visited标记的更新时机注意递归深度限制(可通过sys.setrecursionlimit()调整)BFS常见错误忘记标记已访问节点导致重复处理路径记录方式不当引起内存暴涨队列操作顺序错误影响结果正确性# 可视化调试示例 def print_maze_with_path(maze, path): for i in range(len(maze)): row [] for j in range(len(maze[0])): if (i,j) in path: row.append(*) else: row.append(str(maze[i][j])) print( .join(row))4.3 扩展应用场景这两种算法思想可应用于游戏AI中的路径规划网络爬虫的页面抓取策略社交网络的关系链发现编译器语法分析树的构建在最近一个项目中我需要分析用户行为路径DFS帮助发现了异常循环路径而BFS则优化了关键操作流程的最短引导路径。

相关文章:

Python迷宫寻路实战:用DFS和BFS分别找出所有路径和最短路径(附完整代码)

Python迷宫寻路实战:深度优先与广度优先算法的本质差异 迷宫寻路问题是理解算法思维的经典案例。第一次接触这个问题时,我被同一个迷宫居然能找出多条路径的现象所吸引——这背后隐藏着两种截然不同的搜索策略:深度优先搜索(DFS)和广度优先搜…...

2026办公革命:Gemini3.1Pro一键生成周报会议纪要

很多团队在 2026 年都遇到一个同样的效率问题:资料明明都在,但“整理成可用的周报、会议纪要、行动项”需要反复复制粘贴、改措辞、再统一格式,时间花在了低价值劳动上。于是,越来越多人开始用 AI 做“草稿型文档生成”。在我近期…...

基于Docker与Claude SDK构建AI代理:Nagi项目架构解析与实战

1. 项目概述:构建你的个人AI副驾 如果你和我一样,每天的工作流被Slack、Discord、Asana等工具切割得支离破碎,总是在不同应用间切换,重复着“复制-粘贴-提问-等待”的循环,那么你大概也幻想过能有一个“数字副驾”。它…...

3步解锁《鸣潮》120帧性能飞跃:WaveTools工具箱完全指南

3步解锁《鸣潮》120帧性能飞跃:WaveTools工具箱完全指南 【免费下载链接】WaveTools 🧰鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 还在为《鸣潮》的卡顿和帧率限制烦恼吗?是否觉得60帧的游戏体验无法充分发挥…...

用TWH8778和LM317手搓一个可调开关电源:从12V固定到0-30V可调的完整制作流程

从零打造智能可调电源:TWH8778与LM317的混合架构实战指南 在电子制作和原型开发中,一个可靠的直流电源就像厨师手中的刀具——不同任务需要不同的"刀刃"。传统线性稳压电源虽然输出干净但效率低下,而开关电源高效却可能带来恼人的…...

Skeet到SLV:全栈框架进化与边缘计算实践

1. 项目概述:从Skeet到SLV,一个全栈框架的进化之路 如果你和我一样,在过去几年里一直在全栈开发领域摸爬滚打,那你一定对技术栈的快速迭代和“选择困难症”深有体会。从React到Next.js,从Firebase到各种云服务&#x…...

别再只会用梯度下降了!用Scipy的basinhopping搞定Python全局优化难题(附多元函数实战)

别再只会用梯度下降了!用Scipy的basinhopping搞定Python全局优化难题(附多元函数实战) 当你在训练神经网络时反复调整学习率却始终无法突破准确率瓶颈,当你的物理仿真模型总在某个参数区间卡住,当投资组合优化算法陷入…...

BepInEx终极指南:5步轻松打造Unity游戏插件生态

BepInEx终极指南:5步轻松打造Unity游戏插件生态 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx 想要为Unity游戏添加新功能却担心破坏原始代码?BepInEx插件…...

3步搞定专业级心电监测:AD8232开源方案实战指南

3步搞定专业级心电监测:AD8232开源方案实战指南 【免费下载链接】AD8232_Heart_Rate_Monitor AD8232 Heart Rate Monitor 项目地址: https://gitcode.com/gh_mirrors/ad/AD8232_Heart_Rate_Monitor 想象一下,用不到一杯咖啡的成本,就能…...

自托管内网穿透工具Flompt:从原理到实战部署指南

1. 项目概述:一个被低估的本地隧道工具如果你经常需要把本地开发的服务临时暴露到公网,让同事、客户或者外部服务进行测试和访问,那你一定对“内网穿透”这个概念不陌生。市面上这类工具很多,从老牌的 ngrok,到功能强大…...

从零搭建企业IT管理基石:我的SCCM实战部署与初始配置全记录

从零搭建企业IT管理基石:我的SCCM实战部署与初始配置全记录 当IT基础设施规模突破50台设备时,手工安装补丁和软件部署的效率瓶颈就会突然显现。三年前我接手这家制造企业的IT运维时,发现工程师们每周要花费20小时在不同车间的设备间奔波安装C…...

解锁音乐自由:Unlock-Music浏览器端音乐解密工具完全指南

解锁音乐自由:Unlock-Music浏览器端音乐解密工具完全指南 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: ht…...

AI编程助手插件集:从通用聊天到专业副驾的进化指南

1. 项目概述:一个为AI编程工具量身定制的“插件超市”如果你和我一样,每天都在和Claude Code、Cursor、Codex CLI这些AI编程工具打交道,那你肯定也遇到过类似的烦恼:AI助手写代码时,总喜欢自作主张地过度设计&#xff…...

TShock服主必看:5.1.2版本config.json里那些容易踩坑的隐藏设置

TShock 5.1.2配置精要:从避坑指南到高阶调优手册 当你第一次打开TShock的config.json文件时,可能会被那密密麻麻的参数列表震撼到。作为Terraria服务器的核心控制文件,它远不止是一个简单的设置集合——而是一把双刃剑。正确配置能让服务器如…...

ASMR资源管理新范式:asmroner如何重新定义音频内容获取体验

ASMR资源管理新范式:asmroner如何重新定义音频内容获取体验 【免费下载链接】asmr-downloader A tool for download asmr media from asmr.one(Thanks for the asmr.one) 项目地址: https://gitcode.com/gh_mirrors/as/asmr-downloader 你是否曾为寻找高质量…...

如何在Sass项目中一键实现Retina高清显示适配

如何在Sass项目中一键实现Retina高清显示适配 【免费下载链接】hidpi Serve high resolution graphics to high density (Retina-like) displays with Sass. 项目地址: https://gitcode.com/gh_mirrors/hi/hidpi 还在为不同分辨率设备上的图片显示效果不一致而烦恼吗&am…...

深入BertTokenizer:搞懂中文BERT的5个特殊Token([CLS]、[SEP]等)到底怎么用?

深入解析中文BERT的5个核心特殊标记:从原理到实战 第一次看到BERT代码里那些神秘的[CLS]和[SEP]时,我完全不明白它们存在的意义。直到某个深夜调试模型时,因为漏加了一个[SEP]导致准确率下降了15%,才真正体会到这些特殊标记的重要…...

基于Compose Multiplatform的跨平台AI对话客户端DeepCo开发实践

1. 项目概述:一个跨平台的AI对话客户端最近在折腾AI应用开发,发现市面上的AI对话工具要么是Web端,要么就是平台绑定太死。作为一个喜欢把工具握在自己手里的开发者,我决定自己动手,用Compose Multiplatform技术栈搞一个…...

Java-RPG-Maker-MV-Decrypter:免费开源的游戏资源解密工具完全指南

Java-RPG-Maker-MV-Decrypter:免费开源的游戏资源解密工具完全指南 【免费下载链接】Java-RPG-Maker-MV-Decrypter You can decrypt whole RPG-Maker MV Directories with this Program, it also has a GUI. 项目地址: https://gitcode.com/gh_mirrors/ja/Java-RP…...

TIDAL无损音乐下载器:轻松构建24-bit高音质个人音乐库

TIDAL无损音乐下载器:轻松构建24-bit高音质个人音乐库 【免费下载链接】tidal-dl-ng TIDAL Media Downloader Next Generation! Up to HiRes / TIDAL MAX 24-bit, 192 kHz. 项目地址: https://gitcode.com/gh_mirrors/ti/tidal-dl-ng 想要在TIDAL平台上获取2…...

LAMMPS建模新选择:用EMC和SMILES字符串快速构建PET/PE复合材料模型(附完整ESH文件解析)

LAMMPS建模新选择:用EMC和SMILES字符串快速构建PET/PE复合材料模型(附完整ESH文件解析) 在分子动力学模拟领域,构建精确的初始模型往往是研究的第一步,也是最关键的一步。传统建模工具如Materials Studio虽然功能强大…...

3分钟学会:免费搭建你的专属AI聊天助手

3分钟学会:免费搭建你的专属AI聊天助手 【免费下载链接】ChatGPT-Next-Web ✨ Light and Fast AI Assistant. Support: Web | iOS | MacOS | Android | Linux | Windows 项目地址: https://gitcode.com/GitHub_Trending/ch/ChatGPT-Next-Web 还在为ChatGPT的…...

Arm Neoverse CMN S3(AE)架构与寄存器编程详解

1. Arm Neoverse CMN S3(AE) 架构概述 在现代多核处理器设计中,一致性互连网络是决定系统性能的关键组件。Arm Neoverse CMN S3(AE) 作为第三代一致性网格网络(Coherent Mesh Network)IP,采用了创新的分布式架构设计,为高性能计算场景提供了低…...

不止是教学玩具:在浏览器里用MARIE模拟器调试你的第一个‘操作系统’内核

从零构建微型内核:在MARIE模拟器中探索操作系统核心机制 当我在大学第一次接触操作系统课程时,教授在黑板上画出的那些抽象概念——进程调度、内存管理、系统调用——总让我感到既神秘又遥不可及。直到有一天,我在一个仅有4K字内存的模拟器里…...

3个技术突破:Struts2-Scan实战效能深度验证

3个技术突破:Struts2-Scan实战效能深度验证 【免费下载链接】Struts2-Scan Struts2全漏洞扫描利用工具 项目地址: https://gitcode.com/gh_mirrors/st/Struts2-Scan 在Web安全领域,Struts2框架的漏洞检测一直是技术验证的重要课题。Struts2-Scan作…...

构建AI驱动的无人值守开发流水线:任务编排与智能监控实践

1. 项目概述:告别“一次性”AI助手,实现无人值守的自动化开发流水线如果你和我一样,尝试过用Claude Code、Cursor这类AI编程助手来推进一个需要多步骤、长时间运行的项目,那你一定经历过这种场景:你给AI布置了一个任务…...

Cursor Pro激活器终极指南:3步轻松破解AI编程限制

Cursor Pro激活器终极指南:3步轻松破解AI编程限制 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your trial r…...

Arm Cortex-R82 PMU架构与CLUSTERPMU_PMCFGR寄存器解析

1. Cortex-R82 PMU架构概述在嵌入式实时系统和性能敏感型应用中,硬件性能监控单元(PMU)扮演着至关重要的角色。Arm Cortex-R82处理器作为面向实时计算的高性能处理器,其PMU实现提供了丰富的性能监控能力。与通用处理器不同,R82的PMU设计特别强…...

Maestro:基于声明式YAML的轻量级流程编排工具实践指南

1. 项目概述:一个面向开发者的流程编排利器 最近在梳理团队内部一些重复性的开发运维流程时,我一直在寻找一个能让我“偷懒”的工具。这些流程往往涉及多个步骤:比如代码提交后,自动触发代码质量扫描、依赖安全检查、构建Docker镜…...

4步让旧Mac焕发新生:OpenCore Legacy Patcher硬件适配终极指南

4步让旧Mac焕发新生:OpenCore Legacy Patcher硬件适配终极指南 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 你是否还在为老旧的Mac设备无法升级…...