본문 바로가기

백준/실버

[백준 11048번] 이동하기 (C++)

문제링크 : 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가지이고, 이 중 가장 큰 값을 저장해나간다.