acwing算法基础之搜索与图论--最短路问题

目录

  • [1 基础知识](#1 基础知识)
  • [2 模板](#2 模板)
  • [3 工程化](#3 工程化)

1 基础知识

假设有n个结点,m条边(边的长度或者权重不一致),最短路问题的分类及求解方法如下:

1 单源最短路问题 ,例如求结点1到结点n的最短距离。

1.1 所有边的权重都是正的。

  • 朴素版dijkstra算法,时间复杂度为O(n^2)。时间复杂度与边数无关,适合于稠密图。它是基于贪心实现的。
  • 堆优化版dijkstra算法,时间复杂度为O(mlogn)。适合于稀疏图。它是基于贪心实现的。

1.2 存在负权边。

  • bellman-ford算法,时间复杂度为O(nm)。它是基于离散数学中的一些知识实现的。
  • spfa算法,一般情况下,时间复杂度为O(m);最坏情况下,时间复杂度为O(nm)。

2 多源最短路问题,例如求n个结点中两两结点的最短距离。

  • floyd算法,时间复杂度为O(n^3)。它是基于动态规划实现的。

2 模板

待补充。。。

3 工程化

待补充。。。

相关推荐
wen__xvn3 分钟前
基础算法集训第03天:递推
算法
wen__xvn8 分钟前
算法基础集训第19天:广度优先搜索
算法·宽度优先
这就是佬们吗11 分钟前
力扣---leetcode48
java·笔记·后端·算法·leetcode·idea
薛不痒25 分钟前
项目:矿物分类(训练模型)
开发语言·人工智能·python·学习·算法·机器学习·分类
被星1砸昏头28 分钟前
C++与Node.js集成
开发语言·c++·算法
MicroTech202541 分钟前
微算法科技(NASDAQ :MLGO)开发基于QML的入侵检测识别系统(QML-IDS),强化网络安全防护
科技·算法·web安全
SR_shuiyunjian43 分钟前
Python第一次作业
开发语言·python·算法
期末考复习中,蓝桥杯都没时间学了1 小时前
力扣刷题记录3
算法·leetcode·职场和发展
云深麋鹿1 小时前
一.算法复杂度
c语言·开发语言·算法