算法-Floyd
前置知识
- dp基础
- 图论基础
思路
Floyd 是一种优秀的全源最短路算法。
它的执行过程类似于 dp,如下:
首先我们定义 d i j dij dij 为节点 i i i 到节点 j j j 的最短距离。
我们枚举中转节点 k k k,再枚举两个节点 i , j i,j i,j,显然得到转移方程 d i j = min ( d i j , d i k + d k j ) dij=\min(dij,dik+dkj) dij=min(dij,dik+dkj)。
结束遍历后, d i j dij dij 即为答案。
算法参数
- 时间复杂度: O ( n 3 ) O(n^3) O(n3)
- 空间复杂度: O ( n 2 ) O(n^2) O(n2)
实现代码
cpp
for (int k=1;k<=n;k++)
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
练习
注:在稀疏图中,Floyd 不如跑 n n n 遍 Dijkstra。但是 Floyd 其实是一种 ( min , + ) (\min,+) (min,+) 的广义矩阵乘法,所以有时可以用于解决进阶问题。