300x250
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- linux
- BFS
- AI
- 동적프로그래밍
- 딥러닝
- CSS
- 파이썬
- 킥스타트
- OS
- 운영체제
- PYTHON
- 구글 킥스타트
- DFS
- 프로그래머스
- 알고리즘
- 리눅스
- 백준
- google coding competition
- 그래프
- dp
- 네트워크
- 순열
- 브루트포스
- kick start
- 프로그래밍
- 코딩테스트
- 코딩
- 동적 프로그래밍
- 코딩 테스트
- nlp
Archives
- Today
- Total
오뚝이개발자
[백준 1937] 욕심쟁이 판다 본문
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