알고리즘
백준 17404번 RGB거리2 (JAVA)
박카스마시며코딩
2022. 8. 16. 20:59
https://www.acmicpc.net/problem/17404
17404번: RGB거리 2
첫째 줄에 집의 수 N(2 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 각 집을 빨강, 초록, 파랑으로 칠하는 비용이 1번 집부터 한 줄에 하나씩 주어진다. 집을 칠하는 비용은 1,000보다 작거나
www.acmicpc.net
저는 해당 문제를 DP를 이용하여 해결하였습니다.
저는 마지막 색을 구하고 나머지는 앞의 색과 다르게 선택하고, 마지막에서 2번째는 앞과 맨 뒤에 선택한 것을 선택하지 않도록 하였습니다.
DP를 통해 이전에 계산한 것을 다시 계산하지 않도록 하였습니다.
package BOJ.dp;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
import java.util.function.Function;
public class BOJ_17404 {
private static final int INF = 987654321;
private static final int NOT_VALID = -1;
private static final int SIZE = 3;
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
Function<String,Integer> stoi = Integer::parseInt;
int n = stoi.apply(st.nextToken());
int[][] input = new int[n][n];
for(int i = 0 ; i < n ; i++){
st = new StringTokenizer(br.readLine());
for(int j = 0 ; j < SIZE ; j++){
input[i][j] = stoi.apply(st.nextToken());
}
}
int result = INF;
int[][] dp = new int[n][SIZE];
for(int i = 0 ; i < SIZE ; i++){
init(dp,n);
result = Math.min(result, dfs(0,i,input,n,i,dp) + input[n-1][i]);
}
System.out.println(result);
}
private static void init(int[][] dp, int n) {
for(int i = 0 ; i < n ; i++){
Arrays.fill(dp[i],NOT_VALID);
}
}
private static int dfs(int depth, int prev,int[][] input, int n,int ban,int[][] dp) {
if(depth == n-1){
return 0;
}
if(dp[depth][prev] != NOT_VALID){
return dp[depth][prev];
}
int result = INF;
for(int i = 0 ; i < SIZE ; i++){
if(prev == i){
continue;
}
if(depth == n-2 && i == ban){
continue;
}
result = Math.min(result, dfs(depth+1,i,input,n,ban,dp) + input[depth][i]);
}
dp[depth][prev] = result;
return result;
}
}