python如何表示图_这个python代码如何表示加权有向图

本文介绍了如何用Python表示加权有向图,通过列表示例构建图的数据结构,然后转换为字典形式方便操作。同时,展示了Dijkstra算法的实现过程,用于找到图中两个节点之间的最短路径。示例代码中,dijkstra函数接受起点、终点及邻居关系函数,返回最短距离和路径。
摘要由CSDN通过智能技术生成

我猜列表example的第i元素代表所有宽度为i的边。您可以将图形的数据结构更改为其他内容,例如dict,其中每个键都是一个节点,其值是它所连接的节点的列表,并具有相应的权重。在example = [[(1, 1), (2, 2), (4, 3)], [(1, 3), (3, 4)], [(2, 3), (3, 5)], [(1, 4), (2, 5)], [], []]

nodes = list(set([i for k in example for j in k for i in j ]))

arcs = [(i,example.index(j)) for j in example for i in j]

example_graph = {str(i):[] for i in nodes}

for i in arcs:

example_graph[str(i[0][0])] += [(i[1],str(i[0][1]))]

print example_graph

这给了

^{pr2}$

现在您可以实现Dijkstra算法了,下面是我发现的一个示例:from heapq import heappop,heappush

def dijkstra(s, t, neighbors):

M = set()

d = {s: 0}

p = {}

new = [(0, s)]

while new != []:

dx, x = heappop(new)

if x in M:

continue

M.add(x)

for w, y in neighbors(x):

if y in M:

continue

dy = dx + w

if y not in d or d[y] > dy:

d[y] = dy

heappush(new, (dy, y))

p[y] = x

path = [t]

x = t

while x != s:

x = p[x]

path.insert(0, x)

return d[t], path

def neighbors(s,graph=example_graph):

return graph[s]

例如dijkstra('1', '4', neighbors)返回(2, ['1', '3', '4'])

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值