알고리즘
최단경로 - 3
근즈리얼
2021. 3. 30. 22:27
728x90
Floyd-warshall 알고리즘 : all to all
- 가중치 방향 그래프 G=(V,E), V={1,2,...,n}
- 모든 노드 쌍들간의 최단경로의 길이를 구함
- d^k[i,j] : 중간에 노드집합 {1,2,...,k}에 속한 노드들만 거쳐서 노드 i에서 j까지 가는 최단경로의 길이
i와 j가 바로 연결
첫 번째 : 연결
두 번째 : 연결 x
n개의 노드가 있으므로 i에서 j로 갈 때 n개의 노드를 거쳐서 감
k를 거치지 않고 간다면 d^k-1[i,j]
k를 거쳐서 간다면 d^k-1[i,k] + d^k-1[k,i]
따라서 위의 두 값 중 최솟값을 고르면 된다.
수도코드 - 1
수도코드 - 2
경로 찾기
- 파이 이차원 배열을 만들어준다
- k를 거쳐서 가게 된다면 파이 배열에 k를 넣어준다
경로 출력하기
- i 에서 j까지 가는데 그 사이에 k를 경유한다면 i에서 k까지 출력하고 k에서 j까지 가는 방법을 출력한다.
728x90