2022. 5. 13. 12:51ㆍ알고리즘/최단경로
문제
승균이는 변신로봇에 심취해있었다. 한 분야가 극에 달한 사람은 그것을 통해 세상을 이해한다는 말이 있는데, 승균이가 바로 그러했다. 승균이는 시시때때로 감정이 변하는 사람들을 보면서 사람은 변신로봇과 같다고 생각했다. 또한, 세계의 흐름은 거대한 변신로봇을 조립하는 과정이며, 그 흐름 속에서 우리의 역할은 변신로봇의 부품으로써 다른 부품들과 올바르게 맞물려있는 것에 있다고 믿고 있었다. 그러나 이런 승균이를 보고 있던 승균이의 선생님 준하는 마음이 편치 않았다. 왜냐하면, 자신이 승균이에게 변신로봇을 소개 시켜준 것은 변신로봇을 통해 과학과 수학에 관심을 갖게 하려는 의도였는데, 준하의 의도와는 달리 승균이가 변신로봇을 통해 철학가가 되어가고 있었기 때문이다. 보다 못한 준하는 변신로봇에 동전투입기를 박아버렸다.
이제 변신을 하기 위해선 동전을 넣어야 하는데, 로봇의 현재 상태에서 부품의 형태가 가까운 변신일수록 돈이 적게 들고 먼 형태일수록 돈이 많이 드는 구조이다. 부품의 형태는 숫자로 나타낼 수 있고, 로봇의 상태는 그 숫자들의 모임으로 나타낼 수 있다. 변신에 필요한 돈은 각 부품들의 숫자 차이를 제곱한 것의 합이 된다. 예를 들어 로봇의 현재 상태가 123이고 다른 상태가 222라고 한다면 변신에 필요한 돈은 (1-2)2 + (2-2)2 + (3-2)2인 2가 된다.
승균이는 수학을 전혀 못하기 때문에 이대로 가다간 패닉에 빠질지도 모른다. 불쌍한 승균이를 대신해 돈을 가장 적게 사용해서 승균이가 원하는 변신 상태를 만들어주자.
입력
첫째 줄에 변신로봇의 변신 상태의 개수 N이 주어진다. (1≤N≤1,000)
둘째 줄부터 N줄에 걸쳐 각 변신 상태에 대한 부품의 형태가 숫자로 주어진다. 부품의 형태의 길이는 100을 넘지 않는다. 길이가 다른 부품의 형태는 존재하지 않고, 부품의 형태는 0으로 시작할 수 있다.
다음 줄에 현재 변신 상태의 번호와 승균이가 원하는 변신 상태의 번호가 주어진다. 번호는 위에 입력받은 순서대로 1부터 번호가 매겨져 있다고 가정한다.
출력
첫째 줄에 현재 변신 상태로 승균이가 원하는 변신 상태를 만드는 대에 필요한 돈의 최솟값을 출력한다.
예제 입력 1
3 11 33 55 1 3
예제 출력 1
16
접근 방법
- 다익스트라 최단경로 알고리즘을 활용해 원하는 변신 상태로 만드는 데에 필요한 돈의 최솟값을 출력한다.
코드
# https://www.acmicpc.net/problem/14630
# 접근 방법
# 다익스트라 최단경로 알고리즘을 활용해 원하는 변신 상태로 만드는 데에 필요한 돈의 최솟값을 출력한다.
def dijkstra(start):
distance[start] = 0
h = []
heapq.heappush(h, [0, start])
while h:
dist, now = heapq.heappop(h)
if distance[now] < dist:
continue
for i in range(1, n+1):
if i == now:
continue
cost = dist
for j in range(len(parts[i])):
cost += (parts[i][j] - parts[now][j]) ** 2
if cost < distance[i]:
distance[i] = cost
heapq.heappush(h, [cost, i])
import heapq
n = int(input())
parts = [[]] + [[int(x) for x in input()] for _ in range(n)]
start, end = map(int, input().split())
INF = int(1e9)
distance = [INF for _ in range(n+1)]
dijkstra(start)
print(distance[end])
'알고리즘 > 최단경로' 카테고리의 다른 글
백준 온라인 저지, 최단경로 / 22865번: 가장먼곳 (파이썬 / 백준 골드문제) (0) | 2022.06.23 |
---|---|
백준 온라인 저지, 최단경로 / 5972번: 택배배송 (파이썬 / 백준 골드문제) (0) | 2022.05.16 |
백준 온라인 저지, 최단경로 / 1600번: 말이되고픈원숭이 (파이썬 / , 백준 골드문제) (0) | 2022.04.06 |
백준 온라인 저지, 최단경로 / 9694번: 무엇을아느냐가아니라누구를아느냐가문제다 (파이썬 / , 백준 골드문제) (0) | 2022.02.02 |
백준 온라인 저지, 최단경로 / 11779번: 최소비용구하기2 (파이썬 / , 백준 골드문제) (0) | 2022.01.02 |