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
- 백준
- Kotlin
- 프로래머스
- java
- with recursive
- JVM
- 백준 17779
- springboot
- 백준 16719
- 백준 19238
- sql 기술면접
- 백준 16235
- 웹어플리케이션 서버
- 백준 16236
- 백준 15685
- spring cloud
- 백준 17626
- 프로그래머스
- 백준 파이썬
- spring oauth
- Coroutine
- MSA
- java 기술면접
- JPA
- Spring
- spring security
- 파이썬
- re.split
- MySQL
- Spring Boot
Archives
- Today
- Total
시작이 반
[백준] 9461번(python 파이썬) 본문
SMALL
현재 선택한 색에 따라 나뉘어 지는 경우의 수가 2가지씩 존재한다. 마찬가지로 다음 상태는 이전상태에서 올 수 있는 경우의 수가 2가지 존재한다.
때문에 다음 상태는 이전 상태(2가지)중 작은 값을 찾아서 더해주면 된다.
-> 2차원 배열로 dp를 만들어준다.
첫번째 행은 첫번째 집들의 비용을 넣으면 된다.
import copy
n = int(input())
cost = [list(map(int, input().split())) for _ in range(n)]
dp = [[10001] * 3 for _ in range(n)]
def RGB():
for i in range(n):
for j in range(3):
if i == 0:
dp[i][j] = cost[i][j]
else:
if j == 0:
dp[i][j] = min(dp[i-1][1], dp[i-1][2]) + cost[i][j]
elif j == 1:
dp[i][j] = min(dp[i - 1][0], dp[i - 1][2]) + cost[i][j]
else:
dp[i][j] = min(dp[i - 1][0], dp[i - 1][1]) + cost[i][j]
RGB()
print(min(dp[n-1]))
사실 계속 트리를 그리면서 생각해서 dp 점화식이 떠오르지 않았다..
점화식을 떠올릴때 큰 값을 어떻게 작은값을 이용해서 만드는지 부터 생각하자
답보니까 너무 쉬운 문제였다.
LIST
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 2579번(python 파이썬) (0) | 2021.02.08 |
---|---|
[백준] 1932번(python 파이썬) (0) | 2021.02.08 |
[백준] 9461번(python 파이썬) (0) | 2021.02.06 |
[백준] 20208번(python 파이썬) (0) | 2021.02.04 |
[백준] 1759번(python 파이썬) (0) | 2021.02.04 |