코딩테스트
자료구조/알고리즘 - 최단경로 (2)
Gogozzi
2022. 6. 1. 21:17
반응형
플로이드 워셜(Floyd-Warshall) 알고리즘이란?
모든 최단 경로를 구하는 알고리즘
다익스트라는 하나의 정점에서 다른 모든 정점까지의 최단 거리를 구하는 알고리즘(S.S.S.P - Single Source Shortest Path) 이었다면, 플로이드-워셜 알고리즘은 한 번 실행하여 모든 노드 간 최단 경로를 구할 수 있습니다.
플로이드-워셜 알고리즘은 다익스트라 알고리즘과는 다르게 음의 간선도 사용할 수 있다.
파이썬 코드
INF = int(1e9)
def floyd_warshall(graph):
N = len(graph)
dist = [[INF] * (N + 1) for _ in range(N + 1)]
for idx in range(1, N + 1):
dist[idx][idx] = 0
for start, adjs in graph.items():
for adj, d in adjs:
dist[start][adj] = d
for k in range(1, N + 1):
for a in range(1, N + 1):
for b in range(1, N + 1):
dist[a][b] = min(dist[a][b], dist[a][k] + dist[k][b])
return dist
시간복잡도 O(V^3)
오늘 푼 문제
https://geonoo.tistory.com/138
https://geonoo.tistory.com/139
https://geonoo.tistory.com/140
회고
다익스트라 알고리즘은 출발지 부터 떨어진 다른 노드들의 최단거리만 구할 수 있고, 시간복잡도가 O(NlogN) 이다.
플로이드 워셜 알고리즘은 모든 노드들 사이의 최단거리를 구할 수 있어서 여러 최단경로를 계산해야 할 때 사용하면 좋다.
단, 시간 복잡도가 O(N^3)이기 때문에 노드의 개수와 간서의 개수가 많이지면 효율성이 떨어질 수 있다.
아침부터 꽤나 피곤했다. 평소에 이 정도 까지는 아니었는데 오늘은 더 심했던 것 같다.
피곤이 누적되서 그런지 졸음도 계속오고 정신이 멍해진다...
집중력이 떨어지니까 문제도 잘 안풀리고 괜히 예민해지는것 같다.
결론 자바 람다식만 공부하고 일찍 자야겠다.
반응형