https://www.acmicpc.net/problem/11048
접근방식
DP - 다이나믹 프로그래밍
(r+1, c), (r, c+1), (r+1, c+1)로 이동할 수 있다는 것은 오른쪽, 아래쪽, 대각선으로 갈 수 있다는 것이다.
dp를 사용해 이전 방에서 다음 방으로 이동 했을 때 이전 방의 최대값을 다음 방의 값과 합해야 한다.
즉, 이동할 방이 (r,c) 라면 (r-1,c) (r,c-1), (r-1,c-1) 값 중 최대값을 더한다
import sys
input = sys.stdin.readline
n,m =map(int, input().split())
dp = [[0] * (m + 1) for _ in range(n + 1)]
Map = []
for _ in range(n):
Map.append(list(map(int,input().split())))
for i in range(1, n+1):
for j in range(1, m+1):
dp[i][j] = Map[i-1][j-1] + max(dp[i-1][j], dp[i][j-1],dp[i-1][j-1])
print(dp[n][m])
'Koala - 10기 > 코딩테스트 준비 스터디' 카테고리의 다른 글
[백준/Python]15624번: 피보나치 수 7 (0) | 2023.03.19 |
---|---|
[백준/python] 11055 가장 긴 증가하는 수열 (0) | 2023.03.19 |
[백준/python] 9657 : 돌 게임 3 (0) | 2023.03.18 |
[백준/C++] 9251 : LCS (1) | 2023.03.17 |
[백준/C++] 11726번 2xn 타일링 (0) | 2023.03.17 |