최단 경로 찾기(Shortest Path)

2021. 5. 3. 22:56·SW개발/알고리즘
목차
  1. 다익스트라(Dijkstra) 최단 경로 알고리즘
  2. 시간 복잡도
반응형

최단 경로 찾기(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)이다.
반응형
저작자표시 (새창열림)

'SW개발 > 알고리즘' 카테고리의 다른 글

집합 커버 문제 (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
  1. 다익스트라(Dijkstra) 최단 경로 알고리즘
  2. 시간 복잡도
'SW개발/알고리즘' 카테고리의 다른 글
  • 집합 커버 문제 (Set Cover Problem)
  • 부분 배낭 문제 (Fractional Kanpsack Problem)
  • 최소 신장 트리(Minimum Spanning Tree)
  • 03. 분할 정복 알고리즘
Caniro
Caniro
  • Caniro
    Minimalism
    Caniro
  • 전체
    오늘
    어제
    • 전체보기 (319)
      • SW개발 (268)
        • Java Spring (6)
        • C++ (186)
        • Python (21)
        • Linux (16)
        • 알고리즘 (13)
        • Git (4)
        • Embedded (1)
        • Raspberrypi (9)
        • React (3)
        • Web (2)
        • Windows Device Driver (6)
      • IT(개발아님) (46)
        • Windows (26)
        • MacOS (7)
        • Utility (11)
      • 챗봇 짬통 (0)
      • 일상 (2)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.