[백준] 2×n 타일링 2 (11727)
문제 설명
입력 및 출력
» 입력
첫째 줄에 n이 주어진다. (1 ≤ n ≤ 1,000)
» 출력
첫째 줄에 2×n 크기의 직사각형을 채우는 방법의 수를 10,007로 나눈 나머지를 출력한다.
예제 입출력(테스트케이스)
입력 | 출력 |
---|---|
2 | 3 |
8 | 171 |
12 | 2731 |
문제 풀이(SWIFT) 1
//
// main.swift
// BOJ11727_SWIFT
//
// Created by choiyoujun on 2022/02/14.
//
let N = Int(readLine()!)!
var dp = [Int](repeating: 0, count: 1001)
dp[1] = 1
dp[2] = 3
dp[3] = 5
if N <= 3 {
print(dp[N])
} else {
for i in 4...N {
dp[i] = (dp[i - 1] + (2 * dp[i - 2])) % 10007
}
print(dp[N])
}