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 | 29 | 30 | 31 |
Tags
- BFS
- 브루트포스
- 킥스타트
- 알고리즘
- PYTHON
- kick start
- 코딩 테스트
- 코딩테스트
- DFS
- 운영체제
- 동적프로그래밍
- 파이썬
- 구글 킥스타트
- OS
- AI
- 리눅스
- nlp
- 그래프
- 순열
- linux
- 네트워크
- 동적 프로그래밍
- CSS
- 프로그래밍
- 백준
- google coding competition
- 딥러닝
- 코딩
- 프로그래머스
- dp
Archives
- Today
- Total
오뚝이개발자
[백준 1937] 욕심쟁이 판다 본문
728x90
300x250
문제
https://www.acmicpc.net/problem/1937
나의 풀이
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