[ 프로그래머스 / PYTHON ]3 x n 타일링

yujeongkwon·2022년 7월 27일
0

프로그래머스 / PYTHON

목록 보기
48/77

문제설명

3 x n 타일링
가로 길이가 2이고 세로의 길이가 1인 직사각형 모양의 타일이 있습니다. 이 직사각형 타일을 이용하여 세로의 길이가 3이고 가로의 길이가 n인 바닥을 가득 채우려고 합니다. 타일을 채울 때는 다음과 같이 2가지 방법이 있습니다

타일을 가로로 배치 하는 경우
타일을 세로로 배치 하는 경우
직사각형의 가로의 길이 n이 매개변수로 주어질 때, 이 직사각형을 채우는 방법의 수를 return 하는 solution 함수를 완성해주세요.

풀이 & coment

거꾸로 문제봐도 ✅DP문제
점화식 구해볼려고 노력했지만 몰라서 점화식 찾아봄

내코드

def solution(n):
    answer = 0
    dp = [3,11]
    if n <= 4:  return dp[n//2-1]
    else:
        for i in range(2,n//2):
            dp.append((dp[i-1]*4-dp[i-2])%1000000007)
    return dp[-1]
profile
인생 살자.

0개의 댓글