문제링크 : https://www.acmicpc.net/problem/11048
#include <bits/stdc++.h>
using namespace std;
int n, m;
int dp[1001][1001];
int arr[1001][1001];
int main()
{
cin >> n >> m;
for (int i = 1; i <=n; i++)
{
for (int j = 1; j <=m; j++)
{
cin >> arr[i][j];
dp[i][j] = max(max(dp[i - 1][j], dp[i][j - 1]), dp[i - 1][j - 1]) + arr[i][j]; //3가지 이동 방법으로 온 값중 가장 큰 값을 저장
}
}
cout << dp[n][m]; //구하고자 하는 값 출력
}
이동 방법이 3가지이고, 이 중 가장 큰 값을 저장해나간다.
'백준 > 실버' 카테고리의 다른 글
[백준 2193번] 이친수 (C++) (0) | 2023.02.06 |
---|---|
[백준 14501번] 퇴사 (C++) (0) | 2023.02.06 |
[백준 11722번] 가장 긴 감소하는 부분 수열 (C++) (0) | 2023.02.06 |
[백준 11055번] 가장 큰 증가 부분 수열 (C++) (0) | 2023.02.06 |
[백준 9625번] BABBA (C++) (0) | 2023.02.06 |