문제
https://programmers.co.kr/learn/courses/30/lessons/12900
코딩테스트 연습 - 2 x n 타일링
가로 길이가 2이고 세로의 길이가 1인 직사각형모양의 타일이 있습니다. 이 직사각형 타일을 이용하여 세로의 길이가 2이고 가로의 길이가 n인 바닥을 가득 채우려고 합니다. 타일을 채울 때는
programmers.co.kr
풀이
DP로 해결할 수 있었다. 점화식만 구해주면 레벨3 치고는 그렇게 어렵지 않다.
점화식은 DP(N) = DP(N - 1) + DP(N - 2)이고 그 이유는 DP(5)를 예를들면 DP(5)는 DP(4)에 | 모양 타일을 하나만 넣어주어 만들 수 있고, DP(3)에 -- 모양 타일 두 개를 넣어주면 만들 수 있기 때문이다. 하지만 이런 생각이 들 것이다. DP(3)에 | 모양 타일을 두 개를 넣어줘도 만들 수 있지 않을까? 하지만 DP(4) + | 모양 타일 하나를 통해 만들어진 모양과 이미 겹치기 때문에 이 방법은 개수로 셀 수 없는 것이다.
코드
#include <string>
#include <vector>
#define MOD 1000000007
using namespace std;
int dp[60001];
int solution(int n) {
int answer = 0;
dp[1] = 1;
dp[2] = 2;
dp[3] = 3;
for (int i = 4; i <= n; i++)
{
dp[i] = (dp[i - 1] + dp[i - 2]) % MOD;
}
answer = dp[n];
return answer;
}
'프로그래머스' 카테고리의 다른 글
[프로그래머스] 프로그래머스 Level1 약수의 개수와 덧셈 Java (0) | 2022.05.04 |
---|---|
[프로그래머스] 프로그래머스 Level3 멀리 뛰기 C++ (0) | 2022.05.03 |
[프로그래머스] 프로그래머스 Level1 크레인 인형뽑기 게임 C++ (카카오 코딩테스트) (0) | 2022.05.03 |
[프로그래머스] 프로그래머스 Level2 게임 맵 최단거리 C++ (0) | 2022.05.02 |
[프로그래머스] 프로그래머스 Level1 로또의 최고 순위와 최저 순위 C++ (데브매칭 코딩테스트) (0) | 2022.05.02 |