【发布时间】:2016-03-02 00:02:25
【问题描述】:
我想知道如何在无向图上实现弗洛伊德。有了这个实现,
for k in graph:
for i in graph:
for j in graph:
if dist[i][k] + dist[k][j] < dist[i][j]:
dist[i][j] = dist[i][k] + dist[k][j]
pred[i][j] = pred[k][j]
我能够得到以下的邻接矩阵:
__0 __1 __2 __3 __4
0| 0 28 38 33 63
1| inf 0 10 60 44
2| inf inf 0 50 80
3| inf inf inf 0 30
4| inf inf inf inf 0
这是一个有向图。很好,但我希望邻接矩阵显示无向图。据我了解,对于无向图,这些路径应该沿 0 对角线镜像,但我不知道该怎么做。
我试过了:
for k in graph:
for i in graph:
for j in graph:
if dist[i][k] + dist[k][j] < dist[i][j]:
dist[i][j] = dist[i][k] + dist[k][j]
dist[j][i] = dist[i][k] + dist[k][j]
pred[i][j] = pred[k][j]
但我的图表结果是错误的,看起来算法正在通过不需要的边到达所需的顶点。
__0 __1 __2 __3 __4
0| 0 48 38 93 63
1| 48 0 110 60 44
2| 38 110 0 110 80
3| 93 60 110 0 30
4| 63 inf 80 inf 0
Here is the graph 我正在使用:
{0 : {1:28, 3:33},
1 : {2:10, 4:44},
2 : {3:50},
3 : {4:30},
4 : {}}
编辑:这是完整的代码
import ast
def floyd(graph):
dist = {}
pred = {}
for u in graph:
dist[u] = {}
pred[u] = {}
for v in graph:
dist[u][v] = float('INF')
pred[u][v] = -1
dist[u][u] = 0
for z in graph[u]:
dist[u][z] = graph[u][z]
pred[u][z] = u
for k in graph:
for i in graph:
for j in graph:
if dist[i][k] + dist[k][j] < dist[i][j]:
dist[i][j] = dist[i][k] + dist[k][j]
return dist, pred
graph = {}
graph = ast.literal_eval(open("file2.txt").read())
print graph
dist, pred = floyd(graph)
print " ",
for j in dist: print "__" + str(j),
print "\n"
for i in dist:
print str(i) + "|",
for v in dist: print " %s" % (dist[i][v]),
print "\n"
【问题讨论】:
-
无向图版本与有向图版本相同。如果您原始的未修改算法不适用于有向图,可能是因为您将邻接矩阵设置错误。
-
您能否向我们展示您的完整代码和无法正常工作的示例输入?
-
@user2357112 它确实适用于无向图,而我实际上正在做的是打印出一个 python 字典,只是格式化。也许就是这样,但我仍然看不到发生了什么。我将编辑问题。
-
对于您的无向图,您是否将所有边添加到字典中,例如将
0: 33添加到节点 3 的边? -
@moomin 很酷,但我们仍然无法运行它,因为我们不知道
file2.txt中的内容。请阅读stackoverflow.com/help/mcve。另外,我仍然不确定主要问题是什么——你不想实现什么以及你的代码在哪里失败。问题太乱了。
标签: python algorithm data-structures graph floyd-warshall