๋ฌธ์
https://www.acmicpc.net/problem/1753
ํ์ด
# ๋ฐฑ์ค 1753๋ฒ ๋ฌธ์ - ์ต๋จ๊ฒฝ๋ก
import sys
input = sys.stdin.readline
sys.setrecursionlimit(10**6)
import heapq
n, m = map(int, input().split())
k = int(input())
INF = int(1e9)
graph = [[] * (n+1) for _ in range(n+1)]
distance = [INF] * (n+1)
for _ in range(m):
a, b, c = map(int, input().split())
graph[a].append((b, c))
def dijkstra(start):
q = []
heapq.heappush(q, (0, start))
distance[start] = 0
while q:
dist, now = heapq.heappop(q)
if distance[now] < dist:
continue
for i in graph[now]:
cost = dist + i[1]
if cost < distance[i[0]]:
distance[i[0]] = cost
heapq.heappush(q, (cost, i[0]))
dijkstra(k)
for i in range(1, n+1):
if distance[i] == INF:
print("INF")
else:
print(distance[i])
๋ค์ต์คํธ๋ผ ์๊ณ ๋ฆฌ์ฆ์ ์ฌ์ฉํ์๋ค.
'๐๏ธ Algorithm > ๐ฉ ๋ฐฑ์ค' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
๐ฉ [๋ฐฑ์ค] [Python] [Silver3] 15654๋ฒ_N๊ณผM(5) (0) | 2023.04.18 |
---|---|
๐ฉ [๋ฐฑ์ค] [Python] [Gold3] 2206๋ฒ_๋ฒฝ ๋ถ์๊ณ ์ด๋ํ๊ธฐ (0) | 2023.04.17 |
๐ฉ [๋ฐฑ์ค] [Python] [Gold4] 9663๋ฒ_N-Queen (0) | 2023.04.15 |
๐ฉ [๋ฐฑ์ค] [Python] [Gold4] 5052๋ฒ_์ ํ๋ฒํธ ๋ชฉ๋ก (0) | 2023.04.14 |
๐ฉ [๋ฐฑ์ค] [Python] [Silver4] 1302๋ฒ_๋ฒ ์คํธ์ ๋ฌ (0) | 2023.04.12 |