dijkstra,belllman-ford,spfa最短路算法

 

参考博客优化

 

时间复杂度对比:spa

  Dijkstra:  O(n2.net

  Dijkstra + 优先队列(堆优化):  O(E+V∗logV) blog

  SPFA:  O(k∗E) ,k为每一个节点进入队列的次数,通常小于等于2,最坏状况为O(V∗E)   队列

  BellmanFord: O(V∗E) ,可检测负圈get

  Floyd: O(n3)   计算每对节点之间的最短路径博客

 

结论:
  ① 当权值为非负时,用Dijkstra。
  ② 当权值有负值,且没有负圈,则用SPFA,SPFA能检测负圈,可是不能输出负圈。
  ③ 当权值有负值,并且可能存在负圈,则用BellmanFord,可以检测并输出负圈。
  ④ SPFA检测负环:当存在一个点入队大于等于V次时,则有负环。时间

相关文章
相关标签/搜索