일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 다이나믹프로그래밍
- N-Queens
- 전치사
- IF
- 백트래킹
- 완전탐색
- dfs
- 정렬
- 라이브 아카데미
- 백트래킹 알고리즘
- python
- 관계절
- 알고리즘
- 영어회화
- 회화기초
- 영어 회화
- 라이브아카데미
- 회화
- Hyperledger Fabric
- 백준
- Backtracking Algorithm
- 영어회와
- 영어기초
- used to
- 영어
- 일상회화
- BFS
- 파이썬
- baekjoon
- 블록체인
Archives
- Today
- Total
내 맴
[ 백준 ] 5972번 : 택배 배송 (파이썬) 본문
728x90
문제 )
https://www.acmicpc.net/problem/5972
[ 풀이 IDEA ]
- 다익스트라(Dijkstra) 알고리즘을 이용해서 문제를 해결하였다.
다익스트라 알고리즘은 최소 힙(heapq) 이용해서 풀어주면 좋다는거!! 꼭 기억하자
1️⃣ 초기화 사항
=> 시작점으로 부터의 거리 list(distance), heapq 정의
2️⃣ [시작 점(start) 👉 최소 힙에서 추출한 점(node) 👉 해당 점(node)와 연결된 다른 점(nnode)] 으로 가는 최소거리를 구한다
Distance[nnode] = min(Distance[nnode], 시작점(start)에서 현재 점(node)까지 가는 거리 + 현재 점(node)에서 연결된 점(nnode)로 가는 거리)
- python code
import heapq
import sys
input = sys.stdin.readline
INF = 1e9
def solution(road_info, start, end):
q = [] # 최소 힙
heapq.heappush(q, (0, start))
distance = [INF] * (n+1) # start에서부터 해당 노드까지 가는 최소 거리
distance[start] = 0
while q:
cost, node = heapq.heappop(q)
if node == end:
return distance[node]
# next와 연결된 곳 구하기
for ncost, nnode in road_info[node]:
if ncost + cost < distance[nnode]:
distance[nnode] = ncost + cost
heapq.heappush(q, (cost + ncost, nnode))
n, m = map(int, input().split())
road_info = [[] for _ in range(n+1)]
for i in range(m):
a, b, cost = map(int, input().split())
road_info[a].append((cost, b))
road_info[b].append((cost, a))
print(solution(road_info, 1, n))
728x90
'Algorithm > Baekjoon 문제풀이' 카테고리의 다른 글
[ 백준 ] 16234번 : 인구 이동 (파이썬) (0) | 2023.01.16 |
---|---|
[ 백준 ] 20437번 : 문자열 게임 2 (파이썬) (0) | 2023.01.16 |
[ 백준 ] 3197번 : 백조의 호수 (파이썬) (0) | 2022.12.28 |
[ 백준 ] 1987번 : 알파벳 (BFS / 파이썬) (0) | 2022.12.27 |
[ 백준 ] 14658번 : 하늘에서 별똥별이 빗발친다 (파이썬) (0) | 2022.12.27 |