알고리즘
[백준] 11726 : 2xn 타일링 - Python(파이썬)
Gray__
2021. 8. 8. 22:15
[Silver 3] 11726 : 2xn 타일링 - Python
https://www.acmicpc.net/problem/11726
11726번: 2×n 타일링
2×n 크기의 직사각형을 1×2, 2×1 타일로 채우는 방법의 수를 구하는 프로그램을 작성하시오. 아래 그림은 2×5 크기의 직사각형을 채운 한 가지 방법의 예이다.
www.acmicpc.net
설명
2xn인 사각형을 1x2인 블럭과 2x1인 블럭으로 2xn 사각형을 채울 수 있는 총 경우의 수를 구하는 문제이다
2xn인 경우 n = 1 인 경우부터 차례로 그려가며 생각해보면 알기 편하다
n = 1 => 1가지
n = 2 => 2가지
n = 3 => 3가지
n = 4 => 5가지
.
.
즉 n과 관련된 점화식을 찾을 수 있다.
점화식 : dp[N] = dp[N-1] + dp[N-2]
N = int(input())
res = 0
dp = [0 for _ in range(N+1)]
for i in range(N+1):
if i == 0:
dp[i] = 0
elif i == 1:
dp[i] = 1
elif i == 2:
dp[i] = 2
else:
dp[i] = dp[i-1] + dp[i-2]
print(dp[N] % 10007)