방향 가중치 그래프 와 시작점
가 주어졌을 때, 각 점
에 대하여
와
를 잇는 가장 짧은 경로를 구하라. (
는 꼭짓점의 집합,
는 간선의 집합)
-
시작점에서 모든 꼭짓점까지의 거리를 무한대로 초기화한다.
-
시작점으로의 거리를 0으로 초기화한다.
-
에 속한 모든 간선
(u,v)
에 대해 다음을 반복한다:dist[v] = minimum(dist[v], dist[u] + weight of edge)
-
마지막으로 모든 간선에 대해 음의 사이클(negative cycle)이 없는지 확인한다.
꼭짓점: [A, B, C, D, E]
간선: [A->B, A->C, B->C, B->D, B->E, D->C, D->B, E->D]
가중치: [ -1, 4, 3, 2, 2, 5, 1, -4 ]
시작점: [ A, A, B, B, B, D, D, E ]
꼭짓점 개수 = 5
간선 개수 = 8
// A->B
graph->edge[0].src = A
graph->edge[0].dest = B
graph->edge[0].weight = -1
// A->C
graph->edge[1].src = A
graph->edge[1].dest = C
graph->edge[1].weight = 4
// B->C
graph->edge[2].src = B
graph->edge[2].dest = C
graph->edge[2].weight = 3
// B->D
graph->edge[3].src = B
graph->edge[3].dest = D
graph->edge[3].weight = 2
// B->E
graph->edge[4].src = B
graph->edge[4].dest = E
graph->edge[4].weight = 2
// D->C
graph->edge[5].src = D
graph->edge[5].dest = C
graph->edge[5].weight = 5
// D->B
graph->edge[6].src = D
graph->edge[6].dest = B
graph->edge[6].weight = 1
// E->D
graph->edge[7].src = E
graph->edge[7].dest = D
graph->edge[7].weight = -3
for source = A
꼭짓점 시작점으로부터의 거리
A 0 (A->A)
B -1 (A->B)
C 2 (A->B->C = -1 + 3)
D -2 (A->B->E->D = -1 + 2 + -3)
E 1 (A->B->E = -1 + 2)