[프로그래머스|파이썬] 2 x n 타일링 (연습문제/lv.2)

2023. 5. 26. 16:46·Problem Solving/프로그래머스
반응형
문제

https://school.programmers.co.kr/learn/courses/30/lessons/12900

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

🐍파이썬
더보기

❌ 시간초과 실패 코드

from itertools import product
def solution(n):
    total = n + n % 2
    answer = 0
    for i in range(2, total+1):
        for j in product([1, 2], repeat=i):
            if sum(j) == n:
                answer += 1
    return answer

1과 2로 n을 만들 수 있는 경우의 수를 구하는 문제라고 생각하고 product로 다짜고짜 가능한 모든 중복순열을 만드는 식으로 접근했다가 시간초과로 실패했다. 

def solution(n):
    arr = [0 for _ in range(n)]
    arr[0], arr[1] = 1, 2
    for i in range(2, n):
        arr[i] = (arr[i-1]+arr[i-2])%1000000007
    return arr[n-1]

n과 타일 수를 살펴보면 규칙을 발견할 수 있다.

n = 1: 1 👉 1
n = 2: 2, 11 👉 2
n = 3: 21, 12, 111 👉 3
n = 4: 22, 112, 121, 211, 1111 👉 5

n = 5: 221, 212, 122, 1121, 2111, 1211, 1112, 11111 👉 8...

각 n의 타일 수는 n-1의 타일수 + n-2의 타일수이다.

이를 식으로 정리해 보면 다음과 같다.

arr[n] = arr[n-1] + arr[n-2]

 

n의 값이 최대 60000이기 때문에, 매번 경우의 수를 1,000,000,007으로 나눈 나머지를 넣어줘야 시간초과가 발생하지 않는다.

arr[n] = (arr[n-1] + arr[n-2]) % 1000000007

 

 

다른 풀이 방법

def solution(n):
    a, b = 1, 1
    for i in range(1, n):
        a, b = b, (a + b) % 1000000007
    return b

 

반응형
저작자표시 비영리 변경금지 (새창열림)

'Problem Solving > 프로그래머스' 카테고리의 다른 글

[프로그래머스|파이썬] 큰 수 만들기 (탐욕법(Greedy)/lv.2)  (0) 2023.06.01
[프로그래머스|파이썬] 소수 찾기 (완전탐색/lv.2)  (0) 2023.05.29
[프로그래머스|파이썬] 숫자 변환하기 (연습문제/lv.2)  (0) 2023.05.27
[프로그래머스|파이썬] 2개 이하로 다른 비트(월간 코드 챌린지 시즌2/lv.2)  (0) 2023.05.25
[프로그래머스|파이썬] [1차] 프렌즈4블록 (2018 KAKAO BLIND RECRUITMENT/lv.2)  (0) 2023.05.24
[프로그래머스|파이썬] 모음사전 (완전탐색/lv.2)  (0) 2023.05.24
'Problem Solving/프로그래머스' 카테고리의 다른 글
  • [프로그래머스|파이썬] 소수 찾기 (완전탐색/lv.2)
  • [프로그래머스|파이썬] 숫자 변환하기 (연습문제/lv.2)
  • [프로그래머스|파이썬] 2개 이하로 다른 비트(월간 코드 챌린지 시즌2/lv.2)
  • [프로그래머스|파이썬] [1차] 프렌즈4블록 (2018 KAKAO BLIND RECRUITMENT/lv.2)
청량리 물냉면
청량리 물냉면
프로그래밍 공부를 하고 있습니다. 공부 내용 정리 겸 정보 공유를 목적으로 합니다.
    반응형
  • 청량리 물냉면
    노력중인 블로그
    청량리 물냉면
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 프로그래밍
        • Programming
        • C | C++
        • Java
        • Python
      • 웹 프로그래밍
        • HTML | CSS
        • JavaScript | TypeScript
        • React
        • Vue.js
        • Next.js
        • Spring & Spring Boot
        • JSP & Servlet
        • DB
      • 웹 프로젝트
        • 웹 프로젝트
        • 🥨스낵몰
        • 👨‍👨‍👧‍👧소셜 가계부
        • 🌜꿈 일기장
        • 🔮포트폴리오 사이트
        • 🏃‍♂️팀 프로젝트: 일정관리 프로그램
        • 📈팀 프로젝트: AI기반 주식 분석 플랫폼
        • 😺Just Meow It: 고양이의 조언
      • 앱 프로그래밍
        • Flutter
        • Kotlin
      • Problem Solving
        • 백준
        • 프로그래머스
        • SWEA
      • Computer Science
        • 알고리즘
        • 컴퓨터 네트워크
        • 이산수학
      • Developer
        • 후기
        • 자료정리
        • 취업 | 취준
        • 웹개발 교육 프로그램
        • TIL
  • 블로그 메뉴

    • 홈
    • Github
  • 공지사항

    • 프로그래밍 공부 중😊
  • 인기 글

  • 태그

    ZeroCho
    AWS
    d3
    React
    백준
    SWEA
    Til
    mysql
    클론 프로젝트
    Next.js
    타입스크립트
    spring boot
    플러터
    Jiraynor Programming
    뉴렉처
    리액트
    파이썬
    블로그 제작
    공식문서
    자바스크립트
    bfs
    프로젝트
    알고리즘
    강의내용정리
    자바
    웹사이트
    구현
    포트폴리오
    프로그래머스
    컴퓨터네트워크
  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
청량리 물냉면
[프로그래머스|파이썬] 2 x n 타일링 (연습문제/lv.2)
상단으로

티스토리툴바