弗洛伊德算法
维基百科,自由的百科全书
| 本条目没有列出任何参考或来源。(2013年5月12日) |
Floyd-Warshall算法(Floyd-Warshall algorithm)是解决任意两点间的最短路径的一种算法,可以正確處理有向圖或负权的最短路径問題,同时也被用于计算有向图的传递闭包。
Floyd-Warshall算法的时间复杂度為
,空间复杂度为
。
原理 [编辑]
Floyd-Warshall算法的原理是动态规划。
设
为从
到
的只以
集合中的节点为中间節点的最短路径的长度。
- 若最短路径经过点k,则
; - 若最短路径不经过点k,则
。
因此,
。
在实际算法中,为了节约空间,可以直接在原来空间上进行迭代,这样空间可降至二维。(见下面的算法描述)
算法描述 [编辑]
Floyd-Warshall算法的描述如下:
for k ← 1 to n do
for i ← 1 to n do
for j ← 1 to n do
if (
) then
←
;
其中
表示由點
到點
的代價,當
為 ∞ 表示兩點之間沒有任何連接。
请参阅 [编辑]
|
||||||||||||||||||||
;
。
) then
;