모든 쌍 최단 거리 알고리즘
단일 시작점 최단 거리 알고리즘인 다익스트라, 벨만 포드와 다르게 모든 쌍 최단 거리 알고리즘이다.
음수 사이클이 없는 음수 가중치에서도 작동한다.
vs 다익스트라, 벨만포드
단일 시작점 최단 거리 알고리즘을 모든 정점에서 실행하여도 모든 쌍 최단 거리 알고리즘을 구할 수 있다.
하지만, 구현하기에 플로이드 워샬이 더 간단하다. 또한, 간선이 많은 경우에도 시간 복잡도가 더 낫다.
모든 쌍 최단 거리 시간 복잡도
다익스트라 O(V x ElgE)
벨만포드 O(V x VE)
플로이드 O(V^3)
핵심
1 dist[u][v]
2차월 배열의 dist[u][v]를 사용한다.
u에서 v까지의 최단거리 유지
이동 불가능한 경우는 큰 수로 초기화하며 동일한 정점의 경우는 0으로 초기화한다.
2 정점의 경유점들
u 에서 v까지 최단거리를 구하려고 한다.
모든 정점들은 u, v최단 경로에 속하거나 속하지 않는 두 가지로 고려할 수 있다.
따라서, 어떤 정점 k에 대해 dist[u][v] = min( dist[u][v], dist[u][k] + dist[k][v] ) 와 같이 식을 세울 수 있다.
( 어떤 정점 k를 거치지 않거나, 거친 경우 )
3 과정 및 구현
모든 정점 k 에 대해 k를 거치거나 거치지 않을때를 고려해서 모든 쌍 최단 거리를 구해야 한다.
정점 0을 거치거나 거치지 않았을 때,
정점 0에서
모든 정점까지의 최단 거리
정점 1에서
모든 정점까지의 최단 거리
정점 2에서
모든 정점까지의 최단 거리
.
.
.
=> 정점 0을 거치거나 거치지 않았을 때, 모든 쌍의 최단 거리가 갱신
정점 1 을 거치거나 거치지 않았을 때,
정점 0에서
모든 정점까지의 최단 거리
정점 1에서
모든 정점까지의 최단 거리
정점 2에서
모든 정점까지의 최단 거리
.
.
.
=> 정점 0 or 1을 거치거나 거치지 않았을 때, 모든 정점 쌍의 최단 거리가 갱신
( 정점 0 거치거나 거치지 않았을때 최단 거리가 w에 이미 들어있었다. )
정점 2 을 거치거나 거치지 않았을 때,
정점 0에서
모든 정점까지의 최단 거리
정점 1에서
모든 정점까지의 최단 거리
정점 2에서
모든 정점까지의 최단 거리
.
.
.
=> 정점 0 or 1 or 2을 거치거나 거쳤을때, 대해 모든 쌍 최단 거리 갱신
( 정점 0 or 1 거치거나 거치지 않았을때 최단 거리가 w에 이미 들어있었다. )
이 과정은 모든 정점에 대해 시도하면, 모든 가능한 정점 조합 중 모든 쌍 최단 거리를 구할 수 있게 된다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
/*
w[i][j] : 정점 i에서 j까지 최단 거리(가중치), 경로가 없다면 매우 큰 수
*/
static int[][] adj;
// 모든 쌍 최단 거리 알고리즘
static void floyd(){
for(int i = 0 ; i < V ; i++){
w[i][i] = 0;
}
// 모든 정점 k를 거치거나 거치지 않거나
for(int k = 0 ; k < V ; v++){
// 모든 쌍 i, j 의 최단 거리를 구한다.
for(int i = 0 ; i < V ; i++){
for(int j = 0 ; j < V ; j++){
w[i][j] = Math.min( w[i][j], w[i][k] + w[k][j]);
}
}
}
}
|
cs |
'CS > Algorithm' 카테고리의 다른 글
구현) 정렬 (0) | 2020.03.21 |
---|---|
구현) 큐, 스택 (0) | 2020.03.17 |
선형 자료 구조 (0) | 2020.03.17 |
벨만-포드 알고리즘 ( 자바 ) (0) | 2020.03.04 |
다익스트라(Dijkstra) 알고리즘 ( 자바 ) (0) | 2020.03.01 |