본문 바로가기
Algorithm/BOJ

[BOJ]1149번: RGB거리(c++)

by HBGB 2020. 4. 22.

https://www.acmicpc.net/problem/1149

 

1149번: RGB거리

첫째 줄에 집의 수 N(2 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 각 집을 빨강, 초록, 파랑으로 칠하는 비용이 1번 집부터 한 줄에 하나씩 주어진다. 집을 칠하는 비용은 1,000보다 작거나 같은 자연수이다.

www.acmicpc.net

 

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
32
33
#include <iostream>
#include <algorithm>
 
using namespace std;
 
int main()
{
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
 
    const int MAX = 1000;
    int min_cost[MAX + 1][3];
 
    int T;
    cin >> T;
    for (int i = 1; i <= T; i++)
    {
        int pR, pG, pB;
        cin >> pR >> pG >> pB;
        
        // n번째 집이 R인 경우 : n - 1번째 집이 G or B
        // 둘 중 더 적은 비용에 n번째 색칠 비용을 더하기
        min_cost[i][0= min(min_cost[i - 1][1], min_cost[i - 1][2]) + pR;
        min_cost[i][1= min(min_cost[i - 1][0], min_cost[i - 1][2]) + pG;
        min_cost[i][2= min(min_cost[i - 1][0], min_cost[i - 1][1]) + pB;
    }
 
    // 최소값 출력
    cout << min({ min_cost[T][0], min_cost[T][1], min_cost[T][2] });
 
    return 0;
}
Colored by Color Scripter

 

슬슬 DP문제가 적응되는 것 같다

 

'Algorithm > BOJ' 카테고리의 다른 글

[BOJ]11057번: 오르막 수(c++)  (0) 2020.04.22
[BOJ]1309번: 동물원(c++)  (0) 2020.04.22
[BOJ]15988번: 1, 2, 3 더하기 3(c++)  (0) 2020.04.22
[BOJ]17299번: 오등큰수(c++)  (0) 2020.04.21
[BOJ]17298번: 오큰수(c++)  (0) 2020.04.21

댓글