LeetCode 743 - 网络延迟时间
August 4, 2021
中等题目描述
有 n 个网络节点,标记为 1 到 n。
给你一个列表 times,表示信号经过 有向 边的传递时间。 times[i] = (ui, vi, wi),其中 ui 是源节点,vi 是目标节点, wi 是一个信号从源节点传递到目标节点的时间。
现在,从某个节点 K 发出一个信号。需要多久才能使所有节点都收到信号?如果不能使所有节点收到信号,返回 -1 。
Python题解
方法一:Dijkstra 算法
def networkDelayTime(self, times, n, k):
"""
:type times: List[List[int]]
:type n: int
:type k: int
:rtype: int
"""
g = [[float('inf')] * n for _ in range(n)]
for start, end, time in times:
g[start - 1][end - 1] = time
distance = [float('inf')] * n
distance[k - 1] = 0
used = [False] * n
for _ in range(n):
x = -1
for index, false in enumerate(used):
if not false and (x == -1 or distance[index] < distance[x]):
x = index
used[x] = True
for index, time in enumerate(g[x]):
distance[index] = min(distance[index], distance[x] + time)
ans = max(distance)
return ans if ans < float('inf') else -1
python
总结
题解没看懂,debug了一遍才看懂一点,然后写了点注释 :(
增加测试用例,又debug了一遍,有了新的理解,已更新注释信息。