최단 경로 찾기(Shortest Path)

2021. 5. 3. 22:56·Algorithm/알기 쉬운 알고리즘

최단 경로 찾기(Shortest Path)

  • 가중치 그래프의 어느 한 출발점에서 도착점까지의 최단 경로를 찾는 문제이다.

  • 대표적으로 다익스트라 최단 경로 알고리즘이 있다.


다익스트라(Dijkstra) 최단 경로 알고리즘

  • 프림의 최소 신장 트리(MST) 알고리즘과 비슷하다.

  • 주어진 출발점에서부터 최단 거리인 점을 하나씩 확정해가며 각 점까지의 최단 거리를 점차 업데이트하는 방식이다.

  • 입력으로 주어지는 그래프에는 각 점과 선분에 대한 정보가 있다고 가정한다.

    Pseudo Code

    ShortestPath(Graph g, Node start)
    {
      int dist[n];  // 최단 거리를 저장한 배열
      dist[start] = 0;
      start를 제외한 나머지는 inf로 초기화시킨다.
      while (최단 거리가 확정되지 않은 점이 있다면)
      {
        start로부터 최단 거리가 확정되지 않은 점들 중 최소 거리인 점 v_min에 대해 dist[v_min]을 확정시킨다.
        start로부터 v_min을 통해 갈 수 있는 각 점 w에 대해 dist[w]를 갱신한다.
      }
      return dist;
    }


시간 복잡도

  • 반복문이 (n - 1)번 반복되고, dist 배열에서 v_min을 찾을 때 O(n) 시간이 걸리므로 시간 복잡도는 O(n2)이다.
저작자표시 (새창열림)

'Algorithm > 알기 쉬운 알고리즘' 카테고리의 다른 글

집합 커버 문제 (Set Cover Problem)  (0) 2021.05.03
부분 배낭 문제 (Fractional Kanpsack Problem)  (0) 2021.05.03
최소 신장 트리(Minimum Spanning Tree)  (0) 2021.05.03
03. 분할 정복 알고리즘  (0) 2021.04.30
선택 문제 (Selection Problem)  (0) 2021.04.30
'Algorithm/알기 쉬운 알고리즘' 카테고리의 다른 글
  • 집합 커버 문제 (Set Cover Problem)
  • 부분 배낭 문제 (Fractional Kanpsack Problem)
  • 최소 신장 트리(Minimum Spanning Tree)
  • 03. 분할 정복 알고리즘
Caniro
Caniro
  • Caniro
    Minimalism
    Caniro
  • 전체
    오늘
    어제
    • 분류 전체보기 (317)
      • Algorithm (13)
        • 알기 쉬운 알고리즘 (10)
        • Search (1)
        • Sort (2)
      • Arduino (0)
      • C++ (185)
        • Class (46)
        • Exception (6)
        • Library (51)
        • Overloading (10)
        • SmartPointer (5)
        • Syntax (33)
        • TBC++ (23)
        • Templates (9)
        • VisualStudio (2)
      • Embedded (1)
      • Git (4)
      • Java (5)
      • Linux (16)
        • Error (1)
        • Linux Structure (11)
      • MacOS (7)
      • OS (1)
        • Concurrency (1)
      • Python (21)
        • Class (1)
        • Function (2)
        • Syntax (17)
      • Raspberrypi (9)
      • Review (1)
      • Utility (12)
        • VSCode (5)
        • VirtualBox (3)
      • Web (8)
        • Nginx (1)
        • React (3)
        • Django (1)
      • Windows (20)
        • Registry (3)
        • WSL (1)
        • DeviceDriver (6)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    제외
    SunOS 5.1
    알림
    윈도우
    EXCLUDE
    java
    vscode
    맥북 카카오톡 알림 안뜸
    citrix workspace
    Windows 11
    SFC
    스프링 프레임워크 핵심 기술
    윈도우 명령어
    spring
    Workspace
    MacOS
    백기선
    KakaoTalk
    mspaint
    windows
    unix
    Solaris 10
    스프링
    시스템 복구
    로지텍 마우스 제스처
    dism
    그림판
    logi options
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Caniro
최단 경로 찾기(Shortest Path)
상단으로

티스토리툴바