오뚝이개발자

[백준 1937] 욕심쟁이 판다 본문

코딩 테스트/백준

[백준 1937] 욕심쟁이 판다

땅어 2021. 7. 3. 16:04
728x90
300x250

문제


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

 

1937번: 욕심쟁이 판다

n*n의 크기의 대나무 숲이 있다. 욕심쟁이 판다는 어떤 지역에서 대나무를 먹기 시작한다. 그리고 그 곳의 대나무를 다 먹어 치우면 상, 하, 좌, 우 중 한 곳으로 이동을 한다. 그리고 또 그곳에서

www.acmicpc.net

 

 

나의 풀이


DFS와 DP가 합쳐진 유형의 문제이다. 시작지점이 정해진 것이 아니므로 각 지점을 시작지점으로 했을 때 최장거리를 계산해 이들 중 다시 가장 큰 값을 답으로 출력하는 문제이다. 그냥 단순히 모든 지점을 시작점으로 해서 DFS로 탐색해도 되지만 이미 했던 연산을 중복해서 계산하므로 시간초과가 난다. 따라서 DP를 사용해 해당 지점을 시작점으로 했을 때 갈 수 있는 최장경로를 매 순간 기록해 메모이제이션을 한다.

 

코드


import sys
sys.setrecursionlimit(10**9)

def dfs(x,y):
    if dp[x][y]:
        return dp[x][y]
    dp[x][y] = 1
    dirs = [(1,0),(-1,0),(0,1),(0,-1)]
    for dx,dy in dirs:
        nx, ny = x+dx, y+dy
        if 0<=nx<N and 0<=ny<N and forest[x][y]<forest[nx][ny]:
            dp[x][y] = max(dp[x][y], dfs(nx,ny)+1)
    return dp[x][y]

N = int(input())
forest = [list(map(int, input().split())) for _ in range(N)]
dp = [[0 for _ in range(N)] for _ in range(N)]
for i in range(N):
    for j in range(N):
        dp[i][j] = dfs(i,j)
print(max(map(max,dp)))

 

 

 

 

728x90
300x250

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

유레카 이론  (0) 2021.07.13
[백준 2252] 줄 세우기  (0) 2021.07.04
[백준9376] 탈옥  (0) 2020.05.15
[백준13913] 숨바꼭질 4  (0) 2020.05.14
[백준1525] 퍼즐  (0) 2020.05.05
Comments