문제 설명
접근법
- 행이
지금까지 지나온 도시의 개수
, 열이 도시번호
인 dp배열을 만들었습니다.
dp[i][j]는 도시를 i개 지나서 j번 도시에 도착했을 때의 최댓값이 됩니다.
정답
import java.util.*;
import java.io.*;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int M = Integer.parseInt(st.nextToken());
int K = Integer.parseInt(st.nextToken());
int[][] scoreBoard = new int[N+1][N+1];
for (int i = 0; i < K; i++) {
st = new StringTokenizer(br.readLine());
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
int c = Integer.parseInt(st.nextToken());
scoreBoard[a][b] = Math.max(scoreBoard[a][b], c);
}
int[][] dp = new int[M+1][N+1];
for (int i = 0; i <= M; i++) {
Arrays.fill(dp[i],Integer.MIN_VALUE);
}
dp[1][1] = 0;
for (int i = 1; i <= M; i++) {
for (int j = 1; j <= N; j++) {
for (int k = 1; k < j; k++) {
if(scoreBoard[j-k][j] == 0 || dp[i-1][j-k] == Integer.MIN_VALUE) continue;
dp[i][j] = Math.max(dp[i][j], dp[i-1][j-k]+scoreBoard[j-k][j]);
}
}
}
int answer = 0;
for (int i = 0; i <=M; i++) {
answer = Math.max(dp[i][N], answer);
}
System.out.println(answer);
}
}