[백준] 1005번 - ACM Craft (Gold 3)
업데이트:
문제 링크
문제 설명
주어진 건물 건설 규칙을 만족하면서 특정 건물을 짓는데 걸리는 최소 시간을 출력한다. 건물 건설 규칙은 두 가지로 이루어져 있다.
- 각 건물 당 건설에 걸리는 시간
- 건물 1번부터 N번까지 순서대로 짓는데 걸리는 시간이 주어진다.
- 건물 건설 순서
- 건물을 짓기 전에 반드시 먼저 지어져야하는 건물들의 번호가 주어진다.
정답 코드 및 설명
건물 i를 짓는데 걸리는 시간을 $A_i$, 건물 건설 규칙을 만족하면서 짓는데 걸리는 최소 시간을 $T_i$라고 하자.
건물 W를 짓기 전에 지어야하는 건물들이 $V_1, \cdots, V_k$라면 $T_W = \textrm{max}(A_{V_1}, \cdots A_{V_k}) + A_W$이다.
건설 순서는 항상 모든 건물이 건설 가능하도록 주어진다고 했으므로, 사이클이 도는 경우는 없고 언젠가는 이 과정이 끝날 것이다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import java.io.*;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.StringTokenizer;
public class BOJ1005 {
int n, k, w;
int[] time;
int[] minTime;
ArrayList<Integer>[] parents;
void input(BufferedReader br) throws IOException {
StringTokenizer st = new StringTokenizer(br.readLine());
n = Integer.parseInt(st.nextToken());
k = Integer.parseInt(st.nextToken());
time = new int[n];
parents = new ArrayList[n];
st = new StringTokenizer(br.readLine());
for (int i = 0; i < n; i++) {
time[i] = Integer.parseInt(st.nextToken());
parents[i] = new ArrayList<>();
}
int before, after;
for (int i = 0; i < k; i++) {
st = new StringTokenizer(br.readLine());
before = Integer.parseInt(st.nextToken()) - 1;
after = Integer.parseInt(st.nextToken()) - 1;
parents[after].add(before);
}
w = Integer.parseInt(br.readLine()) - 1;
}
int time(int w) {
if (minTime[w] != -1) {
return minTime[w];
}
int maxTime = 0;
int curr;
for (int i : parents[w]) {
curr = time(i);
if (curr > maxTime) maxTime = curr;
}
minTime[w] = maxTime + time[w];
return minTime[w];
}
void solution() throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int t = Integer.parseInt(br.readLine());
while (t-- > 0) {
input(br);
minTime = new int[n];
Arrays.fill(minTime, -1);
bw.write(time(w) + "\n");
}
bw.close();
}
public static void main(String[] args) throws IOException {
new BOJ1005().solution();
}
}
댓글남기기