문제 출처: https://www.acmicpc.net/problem/1149
문제
RGB거리에는 집이 N개 있다. 거리는 선분으로 나타낼 수 있고, 1번 집부터 N번 집이 순서대로 있다.
집은 빨강, 초록, 파랑 중 하나의 색으로 칠해야 한다. 각각의 집을 빨강, 초록, 파랑으로 칠하는 비용이 주어졌을 때, 아래 규칙을 만족하면서 모든 집을 칠하는 비용의 최솟값을 구해보자.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(reader.readLine());
int[][] DP = new int[N][3]; // 0: R, 1: G, 2: B
for (int i = 0; i < N; i++) {
StringTokenizer tokenizer = new StringTokenizer(reader.readLine());
int R = Integer.parseInt(tokenizer.nextToken());
int G = Integer.parseInt(tokenizer.nextToken());
int B = Integer.parseInt(tokenizer.nextToken());
DP[i][0] = R;
DP[i][1] = G;
DP[i][2] = B;
}
for (int i = 1; i < N; i++) {
DP[i][0] += Math.min(DP[i - 1][1], DP[i - 1][2]);
DP[i][1] += Math.min(DP[i - 1][0], DP[i - 1][2]);
DP[i][2] += Math.min(DP[i - 1][0], DP[i - 1][1]);
}
System.out.println(Math.min(DP[N - 1][0], Math.min(DP[N - 1][1], DP[N - 1][2])));
}
}