[코딩테스트] 백준 1753번: 최단경로

2024. 3. 8. 19:07·코딩테스트
목차
  1. 1. 아이디어
  2. 2. 시간복잡도
  3. 3. 변수
  4. Code

1. 아이디어

▪ 시작점에서 다른 모든 점으로 최단 경로 -> 다익스트라

▪ 간선 정보 인접리스트에 저장

▪ 거리배열 INF로 초기화

▪ 시작점(0,1) heap에 넣기

▪ heap이 빌때까지 while문 반복

▪ heap에서 꺼내온 받아온 edge가 최신 값인지 확인

   - 최신값 아니면 continue

   - 최신값이면

      - 해당 노드를 거쳐서 인근 노드로 가는 비용이 작으면

          - 인근 노드로 가는 비용 갱신

          - heap에 인근 노드 넣기

2. 시간복잡도

▪ log(ElogV)

3. 변수

▪ 최단 경로값 저장할 리스트: int[]

▪ 간선정보 인접리스트(가중치,다음노드): (int,int)[][]

▪ (가중치, 다음노드)를 저장할 heap

Code

import sys
import heapq
input = sys.stdin.readline
INF = sys.maxsize
V,E = map(int,input().split())
K = int(input())
edges = [[] for _ in range(V+1)]
for _ in range(E):
u,v,w = map(int,input().split())
edges[u].append([w,v])
rs = [INF for _ in range(V+1)]
rs[K] = 0
heap = [[0,K]]
while heap:
w, node = heapq.heappop(heap)
if rs[node] != w: continue
for nw, next_node in edges[node]:
if rs[next_node] > w + nw:
rs[next_node] = w + nw
heapq.heappush(heap, [rs[next_node], next_node])
for i in range(1,V+1):
if rs[i] == INF: print("INF")
else: print(rs[i])
 

1753번: 최단경로

첫째 줄에 정점의 개수 V와 간선의 개수 E가 주어진다. (1 ≤ V ≤ 20,000, 1 ≤ E ≤ 300,000) 모든 정점에는 1부터 V까지 번호가 매겨져 있다고 가정한다. 둘째 줄에는 시작 정점의 번호 K(1 ≤ K ≤ V)가

www.acmicpc.net

 

 

'코딩테스트' 카테고리의 다른 글

[코딩테스트] 프로그래머스 - 정수 삼각형  (0) 2024.03.26
[코딩테스트] 백준 11404번: 플로이드  (0) 2024.03.08
[코딩테스트] 백준 1197번: 최소 스패닝 트리  (1) 2024.03.08
[코딩테스트] 백준 11726번: 2×n 타일링  (0) 2024.03.08
[코딩테스트] 백준 11047번: 동전 0  (0) 2024.03.08
  1. 1. 아이디어
  2. 2. 시간복잡도
  3. 3. 변수
  4. Code
'코딩테스트' 카테고리의 다른 글
  • [코딩테스트] 프로그래머스 - 정수 삼각형
  • [코딩테스트] 백준 11404번: 플로이드
  • [코딩테스트] 백준 1197번: 최소 스패닝 트리
  • [코딩테스트] 백준 11726번: 2×n 타일링
Doodo
Doodo
DoodoDoodo 님의 블로그입니다.
  • Doodo
    Doodo
    Doodo
  • 전체
    오늘
    어제
    • 분류 전체보기 (192)
      • CS (17)
        • Network (11)
        • Database (6)
      • Language (19)
        • Python (11)
        • SQL (6)
        • R (2)
      • Linux (17)
      • DevOps (35)
        • Git (7)
        • Docker (8)
        • Kubernetes (9)
        • GCP (4)
        • AWS (7)
      • Data Engineering (50)
        • 책 리뷰 (14)
        • Airflow (35)
        • Redis (1)
      • DBMS (21)
        • CUBRID (21)
      • ML & DL (2)
      • 코딩테스트 (24)
      • 프로젝트 (7)
        • 서울시 대기현황 데이터 적재 프로젝트 (4)
        • CryptoStream (3)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
Doodo
[코딩테스트] 백준 1753번: 최단경로
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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