음수 간선이 포함된 상황에서의 최단 거리 문제
벨만 포드 최단 경로 알고리즘
- 음수 간선에 관하여 최단 경로 문제는 다음과 같이 분류할 수 있다.
- 벨만 포드 최단 경로 알고리즘은, 음의 간선이 포함된 상황에서도 사용할 수 있다.
벨만 포드 알고리즘 vs 다익스트라 알고리즘
import sys
input = sys.stdin.realine
INF = int(1e9)
def bf(start):
dist[start] = 0
for j in range(n):
cur = edges[j][0]
next_node = edges[j][1]
cost = edges[j][2]
if dist[cur] != INF and dist[next_node] > dist[cur] + cost:
dist[next_node] = dist[cur] + cost
if i == n - 1:
return True
return False
n, m = map(int, input().split())
edges = []
dist = [INF] * (n + 1)
for _ in range(m):
a, b, c = map(int, input().split())
edges.append((a, b, c))
negative_cycle = bf(1)
if negative_cycle:
print("-1")
else:
for i in range(2, n + 1):
if dist[i] == INF:
print("-1")
else:
print(dist[i])