#include <string> #include <vector> using namespace std; int solution(int m, int n, vector<vector<int>> puddles) { int dp[110][110] = {0}; // dp[n][m] // 세로 1로 표시 for(int i = 1; i <= n; i++) { dp[i][1] = 1; } // 가로 1로 표시 for(int i = 1; i <= m; i++) { dp[1][i] = 1; } // 웅덩이 -1로 표시 for(int i = 0; i < puddles.size(); i++) { dp[puddles[i][1]][puddles[i][0]] = -1; } for(int i = 1; i <= n; i++) { for(int j = 1; j <= m; j++) { // 집 if(i == 1 && j == 1) { continue; } // 웅덩이 if(dp[i][j] == -1) { dp[i][j] = 0; } else { dp[i][j] = (dp[i-1][j] + dp[i][j-1]) % 1000000007; } } } return dp[n][m]; } | cs |
'Programmers > Level 3' 카테고리의 다른 글
[프로그래머스 3] 입국 심사 (C/C++) (0) | 2020.01.27 |
---|---|
[프로그래머스 3] 예산 (C/C++) (0) | 2020.01.26 |
[프로그래머스 3] 타일 장식물 (C/C++) (0) | 2020.01.11 |
[프로그래머스 3] 정수 삼각형 (C/C++) (0) | 2020.01.11 |
[프로그래머스 3] 저울 (C/C++) (★) (0) | 2020.01.11 |