基础图论 - 最短路
基础图论之最短路
朴素版的Dijkstra算法
- 稠密图:数据范围 m~n^2 (m = 1e5, n = 500),复杂度n^2,邻接矩阵存图
- 解题思路:外层迭代 n 次,每次确定一个点的最短路,st[i] 表明当前已确定最短距离的点,确定最短距离的点 t 之后,用 t 更新其他点的距离。
堆优化版的Dijkstra算法
- 稀疏图:数据范围 m~n (m = 1e5, n = 1e5),复杂度mlogn,邻接表存图
- 解题思路:遍历每条边,如果dist[j] > distance + w[i], 则更新到点 j 的距离,队列维护点 j 以及从源点到点 j 的最短距离,遍历边的时间复杂度 m ,在优先队列中更新一个点的时间复杂度为 logn,总时间复杂度为 mlogn,st[i]含义同上。
Bellman_ford算法
- 时间复杂度:O(mn) ,外层 k(k~n)个循环,确定从1号点到n号点的最多经过k条边的最短距离,内从每次遍历m条边。
- Bellman_ford算法着重解决有边数限制的最短路。
SPFA算法
- SPFA算法 是对 Bellman_ford 算法的优化,后者会遍历所有的边,因此会有很多无意义的更新,而我们只用遍历那些到源点距离变小的点所连接的边即可,只有当一个点的前驱结点更新,该节点才会得到更新,因此考虑到这一点,我们将创建一个队列每一次加入距离被更新的结点。
- spfa可以判断负环,因为只要距离更新就会有元素入队,可以用一个cnt数组记录每个点到源点的边数,一个点被更新一次就+1,一旦有点的边数达到了n,就证明存在负环。
Floyd算法
- Floyd 算法着重解决多源最短距离,时间复杂度 O(n ^ 3)
注意事项和区别
https://www.acwing.com/file_system/file/content/whole/index/content/369161/
为什么Dijkstra不能使用在含负权的图中?
https://www.acwing.com/solution/content/6320/
__EOF__

本文作者:breeze_ku
本文链接:https://www.cnblogs.com/breeze-ku/p/17087802.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/breeze-ku/p/17087802.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App