- 벨만 포드(Bellman-Ford) 최단 경로 알고리즘
- 음수 간선이 포함된 상황에서의 최단 경로 문제에 사용되는 알고리즘
- 위의 그래프처럼 모든 간선이 양수라면 다익스트라 알고리즘을 사용하면 된다.
- 하지만 위의 그래프처럼 일부의 음수 간선이 포함된 경우 어떻게 계산할 수 있을까?
- 일부의 음수 간선이 포함된 경우 최단 거리가 음의 무한인
-INF
가 나오는 노드가 생길 수 있다.
벨만 포드 최단 경로 알고리즘
- 음수 간선에 관하여 최단 경로 문제는 다음과 같이 분류할 수 있다.
- 벨만 포드 최단 경로 알고리즘은 음의 간선이 포함된 상황에서도 사용할 수 있다.
- 음수 간선의 순환을 감지할 수 있다.
- 벨만 포드의 기본 시간복잡도는
O(VE)
로 다익스트라 알고리즘에 비해 느리다.
벨만 포드 최단 경로 알고리즘 동작 과정
- 최단 경로 알고리즘인 다익스트라 알고리즘과 벨만 포드 알고리즘의 차이점은 다음과 같다.
벨만 포드 최단 경로 알고리즘 소스코드
import sys
input = sys.stdin.realine
INF = int(1e9)
def bf(start):
dist[start] = 0
for i in range(n):
for j in range(m):
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])