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
- spring
- 백준
- 스프링 컨테이너와 스프링 빈
- 13460 구슬탈출 2
- Kotlin In Action
- 스프링 핵심 원리 - 기본편
- Kotlin
- 컨베이어 벨트 위의 로봇 Python
- KotlinInAction
- 자바 ORM 표준 JPA 프로그래밍 7장
- 20055
- Python
- 고급매핑
- 코틀린인액션
- 기능개발 python
- 스프링 핵심 원리 이해
- Kotlin in action 6장
- 백준 20055 컨베이어 벨트 위의 로봇
- Kotlin in action 3장
- 백준 13460 Python
- 코틀린
- 7장 고급매핑
- kotlin in action 정리
- 스프링 핵심 원리
- 싱글톤 컨테이너
- Kotlin in action 5장
- 20055 컨베이어 벨트 위의 로봇
- 코틸린인액션
- 객체 지향 설계와 스프링
- Kotlin in action 10장
Archives
- Today
- Total
기록하는 습관
[백준] DP - RGB 거리 본문
i+1번째 집은 i번째 집에 칠한 컬러를 제외한 나머지 색을 칠했을 때의 최소 비용을 생각하며 점화식을 세운다.
import sys
N = int(sys.stdin.readline())
rgb = []
d = [[0] * 3 for _ in range(N)]
for i in range(N):
tmp = list(map(int, sys.stdin.readline().split()))
rgb.append(tmp)
d[0][0] = rgb[0][0]
d[0][1] = rgb[0][1]
d[0][2] = rgb[0][2]
for k in range(1, N):
d[k][0] = min(d[k - 1][1], d[k - 1][2]) + rgb[k][0]
d[k][1] = min(d[k - 1][0], d[k - 1][2]) + rgb[k][1]
d[k][2] = min(d[k - 1][0], d[k - 1][1]) + rgb[k][2]
print(min(d[N - 1][0], d[N - 1][1], d[N - 1][2]))
'알고리즘 > [문제풀이] 백준' 카테고리의 다른 글
[백준] DP - 동전1 (0) | 2020.10.04 |
---|---|
[백준] DP - 연속합 (0) | 2020.10.03 |
[백준] DP - 계단 오르기 (0) | 2020.10.03 |
[백준] DP - 1로 만들기 (0) | 2020.10.03 |
[문제풀이] 경쟁적 전염 (0) | 2020.08.22 |
Comments