Coding - Algo/python

[백준] 4485번:녹색 옷 입은 애가 젤다지? (python 파이썬)

jainn 2021. 7. 17. 22:19
728x90

문제

https://www.acmicpc.net/problem/4485

 

4485번: 녹색 옷 입은 애가 젤다지?

젤다의 전설 게임에서 화폐의 단위는 루피(rupee)다. 그런데 간혹 '도둑루피'라 불리는 검정색 루피도 존재하는데, 이걸 획득하면 오히려 소지한 루피가 감소하게 된다! 젤다의 전설 시리즈의 주

www.acmicpc.net

 

 

풀이 및 소스코드

import sys
input = sys.stdin.readline
from heapq import heappop, heappush
dx = [-1, 1, 0, 0]
dy = [0, 0, -1, 1]
cnt = 1

def bfs():
    dp = [[100000000]*n for _ in range(n)]
    dp[0][0] = arr[0][0]
    v = [[0]*n for _ in range(n)]
    v[0][0] = 1
    hq = []
    heappush(hq, [arr[0][0], 0, 0])
    while hq:
        c, x, y = heappop(hq)
        for i in range(4):
            nowx, nowy = x+dx[i], y+dy[i]
            if 0<=nowx<n and 0<=nowy<n and v[nowx][nowy]==0:
                dp[nowx][nowy] = min(dp[nowx][nowy], dp[x][y]+arr[nowx][nowy])
                heappush(hq, [dp[nowx][nowy], nowx, nowy])
                v[nowx][nowy] = 1
    return dp[-1][-1]

while True:
    n = int(input())
    if n==0:
        break
    arr = [list(map(int, input().split())) for _ in range(n)]
    ans = bfs()
    print('Problem %d: %d'%(cnt, ans))
    cnt += 1
반응형