[백준]1149번 RGB거리 - DP

2021. 2. 8. 18:13·SW개발/코딩테스트

 

n = int(input())

cost = []
for i in range(n):
    cost.append(list(map(int, input().split())))

for i in range(1, n):
    cost[i][0] += min(cost[i-1][1], cost[i-1][2]) # 선택할 수 있는 i-1(이전 값)에서 작은 것을 누적시켜 더함
    cost[i][1] += min(cost[i-1][0], cost[i-1][2])
    cost[i][2] += min(cost[i-1][0], cost[i-1][1])


print(min(cost[-1]))

 

 코드 설명

각 집을 RGB로 칠하는 비용을 먼저 리스트에 저장한다. 그 후 반복문을 돌면서 R, G, B 각각 칠하는 비용을 누적시켜 구한다.

마지막에 저장된 값중 최솟값을 통해 정답을 구할 수 있다.

 

Point : 각 집을 R G B 로 칠하는 3가지의 경우를 모두 구한다. R을 고를 경우에는 G와 B만 칠할 수 있고, G의 경우에는 R과 B, B의 경우에는 R, G를 칠할 수 있다. 이점을 이용하여 전 단계중에서 더 적은 비용을 칠할 수 있는 값을 누적시켜 더한다.

즉, i 번째의 집을 R G B 3가지로 칠하는 경우의 값을 구할 수 있게 된다.

728x90

'SW개발 > 코딩테스트' 카테고리의 다른 글

[백준]2579번 계단 오르기 - DP  (0) 2021.02.10
[백준]1932번 정수 삼각형 - DP  (0) 2021.02.09
[백준]9461번 파도반 수열 - DP  (0) 2021.02.07
[백준]1904번 01타일 - DP  (0) 2021.02.06
[백준]9184번 신나는 함수 실행 - DP  (0) 2021.02.05
'SW개발/코딩테스트' 카테고리의 다른 글
  • [백준]2579번 계단 오르기 - DP
  • [백준]1932번 정수 삼각형 - DP
  • [백준]9461번 파도반 수열 - DP
  • [백준]1904번 01타일 - DP
Leffe_pt
Leffe_pt
개발자로서 성장하면서 배워온 지식과 경험을 공유하는 공간입니다.
  • Leffe_pt
    Leffe's tistory
    Leffe_pt
  • 전체
    오늘
    어제
    • 분류 전체보기 (307)
      • SW개발 (303)
        • 코딩테스트 (172)
        • 개발이야기 (23)
        • IT 용어 (17)
        • Python (22)
        • Django (46)
        • Flask (2)
        • Database (1)
        • SQLAlchemy (0)
        • Javascript (5)
        • Linux, Unix (3)
        • JAVA (2)
        • Spring (10)
      • 회고 (4)
      • 사진 (0)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    트리 #AVL #알고리즘 #자료구조
    Contributor
    배달비 공유
    플레이스토어
    오픈소스
    컨트리뷰터
    배달
    django
    배공파용
    g
    음식
    라이프 스타일
    어플리케이션
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Leffe_pt
[백준]1149번 RGB거리 - DP
상단으로

티스토리툴바