백준 11726번 2*n 타일링

강기호·2023년 2월 8일
0

문제 링크

문제

2×n 크기의 직사각형을 1×2, 2×1 타일로 채우는 방법의 수를 구하는 프로그램을 작성하시오.

아래 그림은 2×5 크기의 직사각형을 채운 한 가지 방법의 예이다.

알고리즘:

  • 다이나믹 프로그래밍
N = int(input()) # 1<=N<=1000
if N ==1:
  d = [0]*3
else:
  d = [0 for i in range(N+1)]
#bottom up
d[1] = 1
d[2] = 2
for i in range(3,N+1):
  d[i] = d[i-1]+d[i-2]
print(d[N] % 10007)

모범담안

n = int(input())
d = [0]*1001
d[0] = 1
d[1] = 1
for i in range(2, n+1):
    d[i] = d[i-1] + d[i-2]
    d[i] %= 10007
print(d[n])

0개의 댓글