From 2dbd06f4f634aedce0b2eae69bf0cb340755e68a Mon Sep 17 00:00:00 2001 From: sm4640 Date: Fri, 27 Mar 2026 09:23:14 +0900 Subject: [PATCH] =?UTF-8?q?11727-s3=20=EC=84=B1=EA=B3=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- workbook_7319/silver/11727-s3.py | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 workbook_7319/silver/11727-s3.py diff --git a/workbook_7319/silver/11727-s3.py b/workbook_7319/silver/11727-s3.py new file mode 100644 index 0000000..a9934b9 --- /dev/null +++ b/workbook_7319/silver/11727-s3.py @@ -0,0 +1,32 @@ +# 2×n 타일링 2 + +import sys + +input = sys.stdin.readline + +def solution(): + n = int(input().rstrip()) + dp = [0] * (n+1) + dp[0] = 1 + dp[1] = 1 + + for i in range(2, n+1): + dp[i] = (dp[i-1]*1) + (dp[i-2]*2) + + print(dp[n]%10007) + + return + + +solution() + +""" +걸린 시간: 10분 + +시간 복잡도: n짜리 테이블을 한번씩만 보면서 채우기 때문에 O(n)이다. + +해설: 과거부터 쌓아온 경우의 수가 현재의 결과에 영향을 미치고, 한 번 결정되면 바뀌지 않기 때문에 dp이다. +현재 1칸이 생겼을 때 과거로부터 놓는 경우를 생각해보면 꽉채워진 상태에서 2x1을 놓는 방법 1가지와 한칸 남겨놓고 2x2에서 만들 수 있는 경우의 수 2가지이다. +이전까지의 경우의 수에 다음 놓을 수 있는 경우의 수가 1가지라면 dp[i-1]*1이고, 2가지일때는 dp[i-2]*2이다. +이 둘을 합친 것이 현재 칸의 경우의 수이다. +""" \ No newline at end of file