0

0

Java中BFS算法实现最短路径的正确姿势与常见陷阱

霞舞

霞舞

发布时间:2025-11-07 13:37:31

|

208人浏览过

|

来源于php中文网

原创

Java中BFS算法实现最短路径的正确姿势与常见陷阱

本文深入探讨了在java中使用广度优先搜索(bfs)算法计算无权图最短路径时可能遇到的问题。重点分析了原始实现中因路径映射错误导致的路径计算不准确问题,并提供了基于父节点回溯的正确bfs算法实现。文章还强调了java中自定义对象在哈希集合中使用时,正确重写equals()和hashcode()方法的重要性,以确保算法的健壮性和正确性。

BFS最短路径算法原理回顾

广度优先搜索(BFS)是一种用于遍历或搜索树或图的算法。它从图的某个节点开始,然后逐层地访问其所有邻居节点,接着访问这些邻居节点的邻居,依此类推。在无权图中,BFS的一个关键特性是它总是能找到从源节点到目标节点的最短路径。这是因为BFS以“层”的方式扩展,第一次访问到任何节点时,其路径必然是最短的。

为了实现BFS并记录路径,我们需要以下核心组件:

  • 队列(Queue):用于存储待访问的节点,确保按层级顺序访问。
  • 已访问集合/路径映射:用于记录哪些节点已被访问,避免重复访问和陷入死循环。同时,它也需要存储节点之间的父子关系,以便最终重建路径。

原代码问题分析

原始代码在尝试计算最短路径时,输出了错误的路径(例如 0 -> 2 -> 3 -> 4 -> 5 而非 0 -> 2 -> 3 -> 4 -> 6 -> 7)。其主要问题在于路径记录机制的缺陷:

  1. 路径记录映射方向错误与覆盖问题: 原始代码使用 Map nextNodeMap 来记录 currentNode 到 nextNode 的映射。这种方式的问题在于,一个 currentNode 可能有多个 nextNode(即一个父节点有多个子节点)。当 nextNodeMap.put(currentNode, nextNode) 被调用多次时,currentNode 作为键的值会被反复覆盖。例如,如果 node4 既连接 node5 又连接 node6,先执行 nextNodeMap.put(node4, node5),后执行 nextNodeMap.put(node4, node6),那么 node4 -> node5 的路径信息就会被 node4 -> node6 覆盖,最终路径重建时可能无法回溯到正确的子节点,从而导致路径错误。

  2. previousNode 变量的误用: 代码中引入了 previousNode 变量,并试图在找到目标节点时使用它来处理多分支情况。然而,这种逻辑未能正确地为每个节点建立唯一的父节点关系,使得路径重建的逻辑变得复杂且容易出错。

  3. 冗余的 visitedNodes 集合: 当正确使用一个映射来记录节点及其父节点关系时(如 Map paths),这个映射本身就可以指示哪些节点已经被访问过(即 paths.containsKey(node)),因此单独的 visitedNodes HashSet 变得冗余。

BFS最短路径的正确实现

为了

立即学习Java免费学习笔记(深入)”;

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

650

2023.06.15

java流程控制语句有哪些
java流程控制语句有哪些

java流程控制语句:1、if语句;2、if-else语句;3、switch语句;4、while循环;5、do-while循环;6、for循环;7、foreach循环;8、break语句;9、continue语句;10、return语句。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

453

2024.02.23

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

722

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

725

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

394

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

441

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

426

2023.08.02

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2万人学习

C# 教程
C# 教程

共94课时 | 5.2万人学习

Java 教程
Java 教程

共578课时 | 36.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号