iOS学习记录首页投稿(暂停使用,暂停投稿)数据结构和算法分析

Swift最短路径之Floyd-Warshall算法

2016-08-01  本文已影响267人  我系哆啦

Floyd-Warshall算法,简称Floyd算法,用于求解任意两点间的最短距离。如下图,表示一个用邻接矩阵表示的图,如何求任意两点之间的距离呢?


floyd.png

<pre>
let max:Int = 10000 //用来表示最大值∞,表示两个顶点之间无边
var map = [[0, 2, 6, 4],
[max, 0, 3, max],
[7, max, 0, 1],
[5, max, 12, 0]]

func floyd(map: inout [Array<Int>]) {
for k in 0..<map.count {
for i in 0..<map.count {
for j in 0..<map.count {
if map[i][j] > (map[i][k] + map[k][j]) {
map[i][j] = (map[i][k] + map[k][j])
}
}
}
}
}
floyd(map: &map)
print(map) //[[0, 2, 5, 4], [9, 0, 3, 4], [6, 8, 0, 1], [5, 7, 10, 0]]
</pre>

上一篇 下一篇

猜你喜欢

热点阅读