数据结构——最短路径BFS算法

一、最短路径问题

1.单源最短路径问题:从一个顶点出发,到达其他任意一个顶点的最短路径。

BFS求无权图的单元最短路径:

对无权图进行广度优先遍历算法,每进行一次,对边权值进行+1.

2.代码实现

对广度优先遍历中的Visit函数进行改造即可。设置两个数组,一个记录各个顶点到原始顶点的最短值,另一个记录每一个顶点在这各最短路径上的直接前驱。

从2号顶点开始,将第一个数组(d)值全部设置为无穷,第二个数组(path)全部设置为-1,再将二号结点的d的值设置为0(起始顶点),再将visited数组中2号的值改为true。 执行while循环,如果队列非空则弹出队列(2号),再从2号开始,找到与它相邻的所有顶点,如果其中有没有访问过的顶点,也就是visited值为false,则更改d++,再修改path,将2号结点填入,修改visited为true。一次循环结束,以此类推(接下来为1)。

(对BFS小修改,在visit一个顶点时,修改其最短路径长度d,在path中记录其前驱。 d的值最大为几,则该图的广度优先生成树的深度为几,且高度最小)

相关推荐
bruk_spp3 分钟前
牛客网华为在线编程题
算法
lkbhua莱克瓦2415 分钟前
Java基础——集合进阶用到的数据结构知识点1
java·数据结构·笔记·github
杨福瑞34 分钟前
数据结构:单链表(2)
c语言·开发语言·数据结构
王璐WL1 小时前
【数据结构】单链表及单链表的实现
数据结构
黑屋里的马2 小时前
java的设计模式之桥接模式(Bridge)
java·算法·桥接模式
z187461030032 小时前
list(带头双向循环链表)
数据结构·c++·链表
sin_hielo2 小时前
leetcode 1611
算法·leetcode
李小白杂货铺2 小时前
识别和破除信息茧房
算法·信息茧房·识别信息茧房·破除信息茧房·算法推荐型茧房·观点过滤型茧房·茧房
来荔枝一大筐3 小时前
C++ LeetCode 力扣刷题 541. 反转字符串 II
c++·算法·leetcode
T.Ree.3 小时前
cpp_list
开发语言·数据结构·c++·list