Floyd-Warshall算法

来自testwiki
跳转到导航 跳转到搜索

Template:TA Template:Infobox Algorithm Template:图搜索算法 Template:Lang算法Template:Lang-en),中文亦称弗洛伊德算法佛洛依德算法[1],是解决任意两点间的最短路径的一种算法[2],可以正確處理有向圖或负权(但不可存在负权回路)的最短路径問題,同时也被用于计算有向图的传递闭包[3]

Template:Lang算法的时间复杂度O(|V|3)[4]空间复杂度O(|V|2),其中V是点集。

原理

Template:Lang算法的原理是动态规划[5]

Di,j,k为从ij的只以(1..k)集合中的节点为中间節点的最短路径的长度。

  1. 若最短路径经过点k,则Di,j,k=Di,k,k1+Dk,j,k1
  2. 若最短路径不经过点k,则Di,j,k=Di,j,k1

因此,Di,j,k=min(Di,j,k1,Di,k,k1+Dk,j,k1)

在实际算法中,为了节约空间,可以直接在原来空间上进行迭代,这样空间可降至二维。

算法描述

Template:Lang算法的伪代码描述如下:

1 let dist be a |V| × |V| array of minimum distances initialized to ∞ (infinity)
2 for each vertex v
3    dist[v][v] ← 0
4 for each edge (u,v)
5    dist[u][v] ← w(u,v)  // the weight of the edge (u,v)
6 for k from 1 to |V|
7    for i from 1 to |V|
8       for j from 1 to |V|
9          if dist[i][j] > dist[i][k] + dist[k][j] 
10             dist[i][j] ← dist[i][k] + dist[k][j]
11         end if

其中dist[i][j]表示由點i到點j的代價,當其為 ∞ 表示兩點之間沒有任何連接。

使用动态规划的算法

实现

Floyd算法在不同的编程语言中均有大量的实现方法:

参考来源

Template:Reflist

参见

Template:算法