티스토리 뷰
모든 쌍 최단 거리 알고리즘
단일 시작점 최단 거리 알고리즘인 다익스트라, 벨만 포드와 다르게 모든 쌍 최단 거리 알고리즘이다.
음수 사이클이 없는 음수 가중치에서도 작동한다.
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 |
- Total
- Today
- Yesterday
- 주사위 윷놀이
- 17779
- 2019 카카오 공채
- 짝지어 제거하기
- 자바
- 단체사진 찍기
- programmers
- java
- 문자열을 정수로 바꾸기
- 게리맨더링 2
- 3954
- 티스토리챌린지
- 오블완
- 투포인터
- 124 나라의 숫자
- 카카오 2020 공채
- 17825
- Brainf**k 인터프리터
- 찾아라 프로그래밍 마에스터
- 가장 큰 정사각형 찾기
- 카카오2020 공채
- 라면공장
- DP
- 프로그래머스
- 2018 카카오 공채
- 괄호 변환
- 백준
- 정수 내림차순으로 배치하기
- 큰 수 만들기
- 후보키
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |