[Algorithm] Dijkstra
다익스트라 알고리즘
다익스트라 알고리즘은 대표적인 최단 경로 탐색 알고리즘이다. 특정한 하나의 정점에서 다른 모든 정점으로 가는 최단 경로를 알려준ㅏ. 그래프의 모든 간선이 0이상의 cost를 가져야 다익스트라 알고리즘을 사용할 수 있다. 또한 그래프에서 연결되지 않는 간선의 가중치는 Inf로 표현하여 다익스트라 알고리즘을 사용하면 편리하다. 하나의 최단 거리는 다른 여러 개의 최단 거리로 이루어져 있기 때문에 하나의 최단 거리를 구할 때 그 이전까지 구했던 최단 거리 정보를 그대로 사용하여 구하므로, 다이나믹 알고리즘 접근 방식과 유사하다.
동작 단계
① 출발 노드를 설정한다. ② ‘최단 거리 테이블’(dist)을 초기화한다. ③ 현재 위치한 노드의 인접 노드 중 방문하지 않은 노드를 구별하고, 방문하지 않은 노드 중 거리가 가장 짧은 노드를 선택한다. 그 노드를 방문 처리한다. ④ 해당 노드를 거쳐 다른 노드로 넘어가는 간선 비용(가중치)을 계산해 ‘최단 거리 테이블’을 업데이트한다. ⑤ ③~④의 과정을 반복한다.
‘최단 거리 테이블’은 1차원 배열로, start에서 N개 노드까지 가는 데 필요한 최단 거리를 기록한다. N개 크기의 배열을 선언하고 큰 값(INF)을 넣어 초기화시킨다. 단, start에 해당하는 부분에는 0을 넣어 초기화한다.
‘노드 방문 여부 체크 배열’(visted)은 방문한 노드인지 아닌지 기록하기 위한 배열로, 크기는 ‘최단 거리 테이블’과 같다. 기본적으로는 0(False)로 초기화하여 방문하지 않았음을 명시한다.
댓글남기기