[ 문제 ]
[ 접근방법 ]
DP를 통해 O( n² ) 만에 문제를 해결할 수 있다.
[ 소스코드 ]
#include <iostream>
using namespace std;
int n, board[105][105];
long long dp[105][105];
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n;
for(int i = 0; i < n; i++)for(int j = 0; j < n; j++)cin >> board[i][j];
dp[0][0] = 1;
for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){
if(i == n - 1 && j == n - 1)break;
if(i + board[i][j] < n){
dp[i + board[i][j]][j] += dp[i][j];
}
if(j + board[i][j] < n){
dp[i][j + board[i][j]] += dp[i][j];
}
}
cout << dp[n - 1][n - 1];
return 0;
}
'PS' 카테고리의 다른 글
[ 백준 / C++ ] 2304 : 창고 다각형 (0) | 2024.12.04 |
---|---|
[ 백준 / C++ ] 5397 : 키로거 (0) | 2024.11.28 |
[ 백준 / C++ ] 1138 : 한 줄로 서기 (0) | 2024.11.20 |
[ 백준 / C++ ] 1913 : 달팽이 (0) | 2024.11.19 |
[ 백준 / C++ ] 7795 : 먹을 것인가 먹힐 것인가 (2) | 2024.11.18 |