https://www.acmicpc.net/problem/1932
import java.io.*;
import java.util.*;
class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[][] arr = new int[N + 1][N + 1];
int[][] dp = new int[N + 1][N + 1];
for (int i = 1; i < N + 1; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
for (int j = 1; j < i + 1; j++) {
arr[i][j] = Integer.parseInt(st.nextToken());
}
}
for (int i = 1; i < N + 1; i++) {
for (int j = 1; j < i + 1; j++) {
dp[i][j] = Math.max(dp[i - 1][j - 1], dp[i - 1][j]) + arr[i][j];
}
}
int result = Arrays.stream(dp[N]).max().getAsInt();
System.out.println(result);
}
}
dp
로 풀어야한다.dp
로 풀어야된다는 것을 알았으면, 핵심은 점화식이다. 각 삼각형의 위치를 인덱스로 나타내면 다음과 같다.arr[4][2]에서의 최대값
은 arr[3][1]까지의 합
과 arr[3][2]까지의 합
중에 더 큰 값을 arr[4][2]
에 더한 값이다.
dp[i][j] = arr[i][j] + Math.max(dp[i-1][j], dp[i-1][j-1])
dp
인줄 모드고 그리디
로 풀었다가 뒤늦게 깨달은 문제였다.dp
문제를 처음 풀어보는 것이었기에, 친구의 도움을 많이 받아서 해결할 수 있었다.dp
를 아직 공부하지 않았기 때문에, dp
문제에 대해서도 꾸준히 풀어봐야겠다.import java.io.*;
import java.util.*;
class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[][] arr = new int[N][N];
int[][] dp = new int[N][N];
for (int i = 0; i < N; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
for (int j = 0; j < i + 1; j++) {
arr[i][j] = Integer.parseInt(st.nextToken());
}
}
dp[0][0] = arr[0][0];
for (int i = 1; i < N; i++) {
for (int j = 0; j < i + 1; j++) {
if (j == 0) {
dp[i][j] = arr[i][j] + dp[i - 1][j];
} else if (j == i) {
dp[i][j] = arr[i][j] + dp[i - 1][j - 1];
} else {
dp[i][j] = arr[i][j] + Math.max(dp[i - 1][j], dp[i - 1][j - 1]);
}
}
}
int result = Arrays.stream(dp[N - 1]).max().getAsInt();
System.out.println(result);
}
}