Knowledge/Algorithm
최단 경로 찾기 알고리즘 (다익스트라 / 플로이드 워셜) (python)
TakeKnowledge
2023. 7. 5. 15:38
반응형
최단 경로를 찾는 알고리즘 중 대표적인 두가지로는 다익스트라 알고리즘과 플로이드 워셜 알고리즘이 있습니다.
다익스트라 알고리즘
- 개념
다익스트라 알고리즘은 출발 노드에서 특정 노드로 가는 최단 경로를 구할 때 사용할 수 있는 알고리즘입니다.
출발 노드부터 시작해 그 노드에서 갈 수 있는 모든 방문하지 않은 노드를 방문 비용이 낮은 것 부터 확인하며 최단 거리 테이블을 갱신해 나가는 방식으로 최단 경로를 구해 나가며, 방문 비용이 낮은 것을 확인하기 위해 heap을 사용하는 것이 특징입니다.
다익스트라 알고리즘의 시간 복잡도는 최대 간선의 개수를 E, 노드의 개수를 V 라고 했을 때 O(ElogV) 입니다.
- 구현
다익스트라 알고리즘 구현은 대표적인 유형인 백준 최소비용 구하기 문제를 예시로 풀며 진행하겠습니다.
플로이드 워셜
- 개념
플로이드 워셜 알고리즘은 모든 지점에서 다른 모든 지점까지의 최단 경로를 모두 구할 수 있는 알고리즘입니다.
노드의 개수를 n이라고 했을 때 n만큼 3중으로 반복하며 모든 노드에 대한 모든 노드의 최단 거리를 저장하는 2차원 배열을 갱신해 나가기 때문에 플로이드 워셜 알고리즘의 시간 복잡도는 O(n^3) 입니다.
- 구현
반응형