几种最短路算法对比
!> 众所周知,关于SPFA,它死了。
几种最短路算法对比:
| 名称 | 时间复杂度 | 优点 | 缺点 | 使用情况 |
|---|---|---|---|---|
| Floyd-Warshall | \(\Theta(n ^ 3)\) | 仅有的多源最短路径算法(即跑一遍Floyd能求出每个点到其它点的距离)、其核心代码就 5 行 | 时间复杂度过高 | 多源最短路、对时间复杂度没要求 |
| Dijkstra(朴素) | \(\Theta(n ^ 2)\) | 编码复杂度非常高、不能处理负权,即边的权值是负数的情况(跟它用的是贪心有关) | ||
| Dijkstra(优先队列优化) | \(\Theta(m \log m) \sim\) | 最快了 | 同朴素版 | 对时间复杂度有要求 |
| Bellman-Ford | \(\Theta(nm)\) | 跟Dijkstra时间复杂度互有胜负,有时还是 Dijkstra赢了 | 稀疏图 | |
| SPFA | 最坏也是 \(\Theta(nm)\) | 优化版Bellman-Ford | 众所周知,它死了 | 稀疏图 |
| Jonson | \(\Theta(nm + nm \log m)\) | 仅有的全源最短路算法,结合了 Dijksra 和 SPFA 的优势 | 不怎么常用…… | |
| BFS | \(\Theta(n + m)\) | 思路简单 | 只能处理等权图或无权图 | 等权图/无权图 |
注:\(n\) 为点的个数,\(m\) 为边的个数。

浙公网安备 33010602011771号