最短路径算法整理
最短路径 1.概念 单源最短路径 单源最短路径实际是计算源点到其他各个顶点的最短路径的长度,常见算法有dijkstra算法 全局最短路径 全局最短路径实际是计算每个源点到其他各个顶点的最短路径的长度,我们可以调用dijkstra算法N次(这样没有Floyd算法快),常见解决全局最短路径的方法是Floyd-Warshall算法,但是Floyd-Warshall算法不能解决负边问题。为了解决负边问题,我们使用Bellman-Ford算法,或者SPFA(Shortest Path Faster Algorithm),SPFA是Bellman-Ford队列优化算法的别称 注意点 很多人看到dijkstra、Floyd-Warshall、SPFA、Bellman-Ford会比较头疼。那就仅先掌握2种算法,优先掌握dijkstra、Floyd-Warshall算法,毕竟,这两个收录在教科书内,理论上来说会比较重要。而在PAT解题过程中,也是优先使用Dijstra算法(PAT往往不会因为短路问题超时)。 2.Dijkstra Dijkstra算法解决单源带权最短路径十分有效。步骤如下: 令S = {源点s + 已经确定了最短路径的顶点vi} 对任一未收录的顶点v,定义dist[v]为s到v的最短路径长度,但该路径仅经过S中的顶点,即路径{ S -> (vi 包含于 S) -> v}的最小长度