알고리즘/알고리즘 기초공부

동빈나 2021 이코테 _ 7. 최단경로 알고리즘 (플로이드 워셜)

이숭간 2021. 3. 20. 20:53
728x90
  • 모든노드에서 다른 모든노드까지의 최단경로를 계산한다.
  • 다익스트라와 마찬가지로 단계별로 거쳐가는 노드를 기준으로 알고리즘을 수행한다.
    • 다만 매 단계마다 방문하지 않은 노드중 최단거리를 갖는 노드를 찾는 과정이 필요없다.
  • 2차원 테이블에 최단거리 정보를 저장한다. 
  • DP유형에 속한다.
  •  

플로이드 워셜 알고리즘  

  • 노드의 개수가 많은경우에는 플로이드워셜보다 다익스트라를 사용하는것이 좋다.
  • 시간복잡도는 O(n^3)임

행은 출발노드, 열은 도착노드를 의미함.

k값만 바꿔가면서 모든a,b를 반복하며 전부 확인해주면 된다.

k = 1일때(1번노드를 거치는) 모든 a,b에 대해서 확인하고 갱신한다.

 소스코드

import sys
input = sys.stdin.readline

INF = int(1e9)

n = int(input()) #노드
m = int(input()) #간선

graph = [[INF]*(n+1) for _ in range(n+1)]

#자신에서 자신으로 가는 비용은 0으로 초기화
for a in range(1, n+1):
    for b in range(1, n+1):
        if a==b:
            graph[a][b]=0

# 간선정보를 받아 그래프정보 입력
for _ in range(m):
    a,b,c = map(int, input().split())
    graph[a][b] = min(graph[a][b], c) # a에서 b로 가는 비용이 c -> 입력중에 같은 도시끼리의 여러값이 들어오므로 그중에서도 제일 작은값을 넣어줘야함

# 플로이드 워셜 알고리즘
for k in range(1, n+1):
    for a in range(1, n+1):
        for b in range(1, n+1):
            graph[a][b] = min(graph[a][b], graph[a][k]+graph[k][b])

#수행결과 출력
for a in range(1, n+1):
    for b in range(1, n+1):
        if graph[a][b] == INF:
            print(0, end=' ')
        else:
            print(graph[a][b], end=' ')
    print()
  • 성능분석 : 각 단계마다 엔제곱의 연산을 통해 현재 노드를 거쳐가는 모든경로를 고려하는데, 이때 현재노드또한 n개로 변해가므로 n의 세제곱의 시간복잡도를 갖는다.