티스토리 뷰

https://www.acmicpc.net/problem/2133

 

2133번: 타일 채우기

문제 3×N 크기의 벽을 2×1, 1×2 크기의 타일로 채우는 경우의 수를 구해보자. 입력 첫째 줄에 N(1 ≤ N ≤ 30)이 주어진다. 출력 첫째 줄에 경우의 수를 출력한다. 예제 입력 1 복사 2 예제 출력 1 복사 3 힌트 아래 그림은 3×12 벽을 타일로 채운 예시이다....

www.acmicpc.net

#include<iostream>
using namespace std;

int d[31];

int dp(int n) {
	if (n == 0) return 1;
	if (n == 1) return 0;
	if (n == 2) return 3;

	if (d[n] != 0) return d[n];

	int result = 3 * dp(n - 2);
	for (int i = 3; i <= n; i++) {
		if (i % 2 == 0)
			result += 2 * dp(n - i);
	}

	return d[n] = result;
}

int main(void) {
	int n;
	cin >> n;
	cout << dp(n) << endl;
}
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/07   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
글 보관함