[BOJ / C++] RGB 거리 (다이나믹 프로그래밍)

2025. 7. 22. 01:06·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/1149

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n;
    cin >> n;

    vector<vector<int>> rgb(n, vector<int>(3));
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < 3; j++) {
            cin >> rgb[i][j];
        }
    }
    
    vector<vector<int>> d(n, vector<int>(3));
    d[0][0] = rgb[0][0];
    d[0][1] = rgb[0][1];
    d[0][2] = rgb[0][2];
    
    for (int i = 1; i < n; i++) {
        d[i][0] = rgb[i][0] + min(d[i-1][1], d[i-1][2]);
        d[i][1] = rgb[i][1] + min(d[i-1][0], d[i-1][2]);
        d[i][2] = rgb[i][2] + min(d[i-1][0], d[i-1][1]);
    }

    cout << min({d[n-1][0], d[n-1][1], d[n-1][2]});
}

 

 

2. 분석

이 문제는 dp 테이블을 잘 잡는 것이 중요하다. dp테이블에서 i번째 rgb를 고정하는 것이 핵심이다. 케이스를 나누려고 생각하면 조건 분기 무한지옥에 빠지게 된다.

 

1. dp 테이블:

d[i][0] = i번째 집까지 칠할 때 비용의 최솟값, 단 i번째 집은 빨강

d[i][1] = i번째 집까지 칠할 때 비용의 최솟값, 단 i번째 집은 초록

d[i][2] = i번째 집까지 칠할 때 비용의 최솟값, 단 i번째 집은 파랑  

 

2. 점화식:

d[k][0] = rgb[k][0] + min(d[k-1][1], d[k-1][2])

 

3. 시간복잡도

2차원 배열을 사용하지만 크기가 n*3이므로 이걸 한번만 순회하면서 테이블을 채우므로 O(n)이다. n = 1000 < 10^7 이므로 시간제한 0.5초 이내에 통과 가능하다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 구간 합 구하기 4 (다이나믹 프로그래밍, prefix sum)  (0) 2025.07.22
[BOJ / C++] 2×n 타일링 (다이나믹 프로그래밍)  (0) 2025.07.22
[BOJ / C++] 1, 2, 3 더하기 (다이나믹 프로그래밍)  (0) 2025.07.21
[BOJ / C++] 1로 만들기 (BFS, 다이나믹 프로그래밍)  (0) 2025.07.21
[BOJ / C++] 치킨 배달 (시뮬레이션)  (0) 2025.07.21
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 구간 합 구하기 4 (다이나믹 프로그래밍, prefix sum)
  • [BOJ / C++] 2×n 타일링 (다이나믹 프로그래밍)
  • [BOJ / C++] 1, 2, 3 더하기 (다이나믹 프로그래밍)
  • [BOJ / C++] 1로 만들기 (BFS, 다이나믹 프로그래밍)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (174) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (17) N
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (1) N
      • 코딩테스트 (96) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] RGB 거리 (다이나믹 프로그래밍)
상단으로

티스토리툴바