Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 꼬마 정민
- Class Delegation
- 백준1476
- 백준3085
- 18108
- 사파리 월드
- dp
- BitMasking
- 10430
- 10807
- 10926
- 1330
- kotlin
- 개수 세기
- 백준
- baekjoon
- safari world
- PreferenceManager
- 디버그심볼
- debugSymbolLevel
- Android
- 새싹
- 25083
- 백준1107
- 코틀린
- 기본메신저
- 2525
- 파이썬
- Counting The number
- 브루트포스
Archives
- Today
- Total
세상을 더 좋게
[백준] 9095 '1, 2, 3 더하기' 파이썬(python) 본문
https://www.acmicpc.net/problem/9095
9095번: 1, 2, 3 더하기
각 테스트 케이스마다, n을 1, 2, 3의 합으로 나타내는 방법의 수를 출력한다.
www.acmicpc.net
T = int(input())
nums = [] # 수들을 담기 위한 리스트
dp = [0] * 11 # DP 테이블. 최대 11이므로 11까지 받는다.
dp[1] = 1
dp[2] = 2
dp[3] = 4
for i in range(4, 11) : # 귀납법으로 규칙을 찾다보면 아래와 같은 규칙이 나온다는 것을 알 수 있다.
dp[i] = dp[i-3] + dp[i-2] + dp[i-1]
for _ in range(T) : # 차례대로 점화식에 대입하여 출력
n = int(input())
print(dp[n])
Point
- DP를 활용한 알고리즘
- 점화식을 먼저 찾는게 중요. 귀납법으로 할 수 있다면 먼저 차례대로 넣어보면서 찾는게 좋다
'Algorithm > DP' 카테고리의 다른 글
[백준] 11727 '2×n 타일링 2' 파이썬(python) (0) | 2021.11.19 |
---|---|
[백준] 11052 '카드 구매하기' 파이썬(python) (0) | 2021.11.19 |
[백준] 11726 '2×n 타일링' 파이썬(python) (0) | 2021.11.19 |
[백준] 1463 '1로 만들기' 파이썬(python) (0) | 2021.11.18 |
[다이나믹 프로그래밍] '피보나치 수열' (0) | 2021.11.18 |