forked from doocs/leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSolution.py
27 lines (26 loc) · 835 Bytes
/
Solution.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
class Solution:
def closestMeetingNode(self, edges: List[int], node1: int, node2: int) -> int:
def dijkstra(i):
dist = [inf] * n
dist[i] = 0
q = [(0, i)]
while q:
i = heappop(q)[1]
for j in g[i]:
if dist[j] > dist[i] + 1:
dist[j] = dist[i] + 1
heappush(q, (dist[j], j))
return dist
g = defaultdict(list)
for i, j in enumerate(edges):
if j != -1:
g[i].append(j)
n = len(edges)
d1 = dijkstra(node1)
d2 = dijkstra(node2)
ans, d = -1, inf
for i, (a, b) in enumerate(zip(d1, d2)):
if (t := max(a, b)) < d:
d = t
ans = i
return ans