[파이썬]백준 1240 노드사이의거리

Byeonghyeon Kim·2021년 4월 29일
0

알고리즘문제

목록 보기
65/93
post-thumbnail

링크

백준 1240 노드사이의거리


탐색해야하는 구간마다 다익스트라를 반복해서 돌려주었다.
무향그래프이기 때문에 다익스트라 함수에 방문처리 로직을 추가해줬다.


정답 코드

import sys; input = sys.stdin.readline
from heapq import heappush, heappop

def dijkstra(start, end):
    dis = [10000000] * (N + 1)
    visit = [0] * (N + 1)
    dis[start] = 0
    q = [[0, start]]
    while q:
        k, u = heappop(q)
        if visit[u] or k > dis[u]: continue
        visit[u] = 1
        for w, v in G[u]:
            if dis[v] > w + dis[u] and not visit[v]:
                dis[v] = w + dis[u]
                heappush(q, [dis[v], v])

    return dis[end]

N, M = map(int, input().split())
G = [[] for _ in range(N + 1)]
for _ in range(N - 1):
    u, v, w = map(int, input().split())
    G[u].append([w, v])
    G[v].append([w, u])

for _ in range(M):
    start, end = map(int, input().split())
    print(dijkstra(start ,end))

알게된 것👨‍💻

  • 구간마다 다 돌려~~
profile
자기 주도 개발전 (개발, 발전)

0개의 댓글