문제
https://www.acmicpc.net/problem/15486
입출력
아이디어
DP.. 오늘 선택하면 오늘 + 걸리는 시간 날짜에 ㄱㄴ..
코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
static int N;
static int[] T, P;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
N = Integer.parseInt(br.readLine());
T = new int[N + 2];
P = new int[N + 2];
for (int i = 1; i <= N; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
T[i] = Integer.parseInt(st.nextToken());
P[i] = Integer.parseInt(st.nextToken());
}
int[] dp = new int[N + 2];
for (int i = 1; i <= N; i++) {
// 상담하지 않고 넘어가기 (다음 날에도 현재 최대 수익 유지)
dp[i + 1] = Math.max(dp[i + 1], dp[i]);
// 상담 가능한 경우
if (i + T[i] <= N + 1) {
dp[i + T[i]] = Math.max(dp[i + T[i]], dp[i] + P[i]);
}
}
System.out.println(dp[N + 1]);
}
}
'Java' 카테고리의 다른 글
[프로그래머스] 연속된 부분 수열의 합 (0) | 2025.03.26 |
---|---|
[프로그래머스] 징검다리 건너기 (0) | 2025.03.25 |
[백준] 2011 : 암호코드 (0) | 2025.03.24 |
[백준] 9084 : 동전 (0) | 2025.03.24 |
[백준] 9657 : 돌 게임3 (0) | 2025.03.24 |