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

带有负权路的,搞不定

相关推荐
蚊子码农42 分钟前
算法题解记录--239滑动窗口最大值
数据结构·算法
额,不知道写啥。2 小时前
HAO的线段树(中(上))
数据结构·c++·算法
blackicexs3 小时前
第五周第七天
数据结构·算法
夏乌_Wx4 小时前
反转链表:三种实现思路与细节梳理
数据结构·链表
紫陌涵光5 小时前
108.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
载数而行5206 小时前
算法系列2之最短路径
c语言·数据结构·c++·算法·贪心算法
fu的博客6 小时前
【数据结构10】满/完全二叉树、顺序/链式存储
数据结构·
逆境不可逃6 小时前
【除夕篇】LeetCode 热题 100 之 189.轮转数组
java·数据结构·算法·链表
wefg17 小时前
【算法】倍增思想(快速幂)
数据结构·c++·算法
Zik----7 小时前
Leetcode24 —— 两两交换链表中的节点(迭代法)
数据结构·算法·链表