gpt4 book ai didi

python - Networkx:获取节点之间的距离

转载 作者:太空狗 更新时间:2023-10-29 22:21:22 26 4
gpt4 key购买 nike

我是使用 NetworkX 的初学者,我正在尝试找到一种方法来检测哪些节点彼此之间的距离为 x。我已经开始使用这个算法来获取所有对

path=nx.all_pairs_dijkstra_path(G)

但我仍然不确定如何使用 for 循环检测节点之间的距离。

如果有任何帮助,我将不胜感激。谢谢

最佳答案

NetworkX 具有自动计算加权和未加权图的最短路径(或仅路径长度)的方法。确保针对您的用例使用正确的方法。

networkx.all_pairs_shortest_path - 计算未加权图中所有节点之间的最短路径

networkx.all_pairs_shortest_path_length - 计算未加权图中所有节点之间的最短路径的长度

networkx.all_pairs_dijkstra_path - 计算加权图中所有节点之间的最短路径

networkx.all_pairs_dijkstra_path_length - 计算加权图中所有节点之间的最短路径的长度

这些方法中的每一个,当在图上执行时,都将计算节点的字典矩阵(“字典的字典”),这些节点具有相应的最短路径或最短路径的长度作为值。我将用一个例子来证明这一点:

>>> import networkx as nx
>>> G = nx.Graph()
>>> G.add_nodes_from(["A", "B", "C", "D", "E"])
>>> G.add_edges_from([("A", "B"), ("B", "C"), ("C", "D"), ("D", "E")])
>>> sp = dict(nx.all_pairs_shortest_path(G))
>>> sp["A"]["E"]
['A', 'B', 'C', 'D', 'E']
>>> spl = dict(nx.all_pairs_shortest_path_length(G))
>>> spl["A"]["E"]
4

如您所见,我生成了一个包含五个节点的图,并使用边将每个节点链接到下一个节点。我在 sp 中存储了一个最短路径矩阵,在 spl 中存储了一个最短路径长度矩阵。当我需要知道两个节点之间的最短路径时,例如节点 "A" 和节点 "E",我只是访问 sp 就像一个矩阵,或者字典的字典:sp[ “A”][“E”]。然后它将返回两个节点之间的整个最短路径。最短路径长度的方法以类似的方式工作,但它只会返回任意两个给定节点之间的边数。

下一个代码片段可能会让我更清楚地了解字典矩阵的含义。如果我请求 sp 中节点 "A" 的所有条目,它会返回另一个字典,其中包含每个其他节点的条目:

>>> sp["A"]
{'B': ['A', 'B'], 'A': ['A'], 'E': ['A', 'B', 'C', 'D', 'E'], 'C': ['A', 'B', 'C
'], 'D': ['A', 'B', 'C', 'D']}

如果您想使用 for 循环检查所有节点之间的距离,您可以只遍历矩阵的第一个字典的键,然后遍历该字典内的字典。这比听起来容易:

>>> for node1 in spl:
... for node2 in spl[node1]:
... print("Length between", node1, "and", node2, "is", spl[node1][node2])
...
Length between B and B is 0
Length between B and A is 1
Length between B and E is 3
Length between B and C is 1
Length between B and D is 2
Length between A and B is 1
... (and so on!)

关于python - Networkx:获取节点之间的距离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40088042/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com