Joe*_*ant 3 python graph floyd-warshall
假设图由n x n
维度邻接矩阵表示.我知道如何获得所有对的最短路径矩阵.但我想知道有没有办法追踪所有最短的路径?Blow是python代码实现.
v = len(graph)
for k in range(0,v):
for i in range(0,v):
for j in range(0,v):
if graph[i,j] > graph[i,k] + graph[k,j]:
graph[i,j] = graph[i,k] + graph[k,j]
Run Code Online (Sandbox Code Playgroud)
您必须在if语句中添加一个新矩阵来存储路径重建数据(p
前一个矩阵的数组):
if graph[i,j] > graph[i,k] + graph[k,j]:
graph[i,j] = graph[i,k] + graph[k,j]
p[i,j] = p[k,j]
Run Code Online (Sandbox Code Playgroud)
在开始时,矩阵p
必须填充为:
for i in range(0,v):
for j in range(0,v):
p[i,j] = i
if (i != j and graph[i,j] == 0):
p[i,j] = -30000 # any big negative number to show no arc (F-W does not work with negative weights)
Run Code Online (Sandbox Code Playgroud)
要重建您必须调用的节点i
和j
节点之间的路径:
def ConstructPath(p, i, j):
i,j = int(i), int(j)
if(i==j):
print (i,)
elif(p[i,j] == -30000):
print (i,'-',j)
else:
ConstructPath(p, i, p[i,j]);
print(j,)
Run Code Online (Sandbox Code Playgroud)
并具有上述功能的测试:
import numpy as np
graph = np.array([[0,10,20,30,0,0],[0,0,0,0,0,7],[0,0,0,0,0,5],[0,0,0,0,10,0],[2,0,0,0,0,4],[0,5,7,0,6,0]])
v = len(graph)
# path reconstruction matrix
p = np.zeros(graph.shape)
for i in range(0,v):
for j in range(0,v):
p[i,j] = i
if (i != j and graph[i,j] == 0):
p[i,j] = -30000
graph[i,j] = 30000 # set zeros to any large number which is bigger then the longest way
for k in range(0,v):
for i in range(0,v):
for j in range(0,v):
if graph[i,j] > graph[i,k] + graph[k,j]:
graph[i,j] = graph[i,k] + graph[k,j]
p[i,j] = p[k,j]
# show p matrix
print(p)
# reconstruct the path from 0 to 4
ConstructPath(p,0,4)
Run Code Online (Sandbox Code Playgroud)
输出:
电话号码:
[[ 0. 0. 0. 0. 5. 1.]
[ 4. 1. 5. 0. 5. 1.]
[ 4. 5. 2. 0. 5. 2.]
[ 4. 5. 5. 3. 3. 4.]
[ 4. 5. 5. 0. 4. 4.]
[ 4. 5. 5. 0. 5. 5.]]
Run Code Online (Sandbox Code Playgroud)
路径0-4:
0
1
5
4
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6525 次 |
最近记录: |