单源最短路径 -- Dijkstra

Dijkstra算法就适用于解决带权重的有向图上的单源最短路径问题 -- 同时算法要求图中所有边的权重非负(这个很重要)

针对一个带权有向图G , 将所有节点分为两组S和Q , S是已经确定的最短路径的节点集合,在初始时为空(初始时就可以将源节点s放入,毕竟源节点到自己的代价是0 ), Q为其余未确定最短路径的节点集合,**每次从Q中找出一个起点到该节点代价最小的节点u,将u从Q中移除,并放入S中,对u每一个相邻节点v进行松弛操作。**松弛即对每一个相邻节点v,判断源节点s到节点u的代价与u到v的代价之和是否比原来的s到v的代价更小,若代价比原来小则要将s到v代价更新为s到u与u到v的代价之后,否则维持原样,如此反复,直到Q集合

贪心策略:每次去选从s->Q 去选最短路径边的那个顶点,去更新其连接的路径

代码实现

Dijstra算法的缺陷

带有负权路的,搞不定

相关推荐
故事和你916 小时前
sdut-程序设计基础Ⅰ-实验五一维数组(8-13)
开发语言·数据结构·c++·算法·蓝桥杯·图论·类和对象
郝YH是人间理想11 小时前
Pandas库DataFrame数据结构
数据结构·pandas
j_xxx404_12 小时前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
我能坚持多久12 小时前
【初阶数据结构07】——栈与队列的代码实现与解析
数据结构
We་ct12 小时前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
Aaswk13 小时前
蓝桥杯2025年第十六届省赛真题(更新中)
c语言·数据结构·c++·算法·职场和发展·蓝桥杯
Yvonne爱编码14 小时前
JAVA数据结构 DAY7-二叉树
java·开发语言·数据结构
总斯霖14 小时前
P15445永远在一起!题解(月赛T2)
数据结构·c++·算法·深度优先
像污秽一样14 小时前
算法设计与分析-习题4.5
数据结构·算法·排序算法·剪枝
样例过了就是过了14 小时前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs