单源最短路径 -- 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算法的缺陷

带有负权路的,搞不定

相关推荐
shymoy20 分钟前
Radix Sorts
数据结构·算法·排序算法
木向2 小时前
leetcode92:反转链表||
数据结构·c++·算法·leetcode·链表
阿阿越2 小时前
算法每日练 -- 双指针篇(持续更新中)
数据结构·c++·算法
小爬虫程序猿4 小时前
如何利用Python解析API返回的数据结构?
数据结构·数据库·python
pianmian18 小时前
python数据结构基础(7)
数据结构·算法
ChoSeitaku11 小时前
链表交集相关算法题|AB链表公共元素生成链表C|AB链表交集存放于A|连续子序列|相交链表求交点位置(C)
数据结构·考研·链表
偷心编程11 小时前
双向链表专题
数据结构
香菜大丸11 小时前
链表的归并排序
数据结构·算法·链表
jrrz082811 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
@小博的博客12 小时前
C++初阶学习第十弹——深入讲解vector的迭代器失效
数据结构·c++·学习