링크 : https://www.acmicpc.net/problem/1005
◆ 위상 정렬을 통해 특정 건물 x를 짓기 위한 선행건물 루트중에 가장 시간이 오래걸리는 루트의 시간을 totaltime[x] 에 넣어줌.
해당 건물을 지을 수 있게되면 (indegree[x] 값이 0이되면) 해당 건물을 짓는 시간(times[x])을 더해줌
없었음
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
using namespace std;
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
int tc;
cin >> tc;
for (int i = 0; i < tc; i++) {
//times : 각 단일 건물들을 짓는데 걸리는 시간
//toaltimes : 해당 건물을 짓기위해 걸리는 총 시간
int n, k, times[1001], indegree[1001], w, totaltime[1001];
vector<int> order[1001];
queue<int> q;
cin >> n >> k;
fill(indegree, indegree + n + 1, 0);
fill(totaltime, totaltime + n + 1, 0);
for (int j = 1; j <= n; j++) cin >> times[j];
for (int j = 0; j < k; j++) {
int x, y;
cin >> x >> y;
indegree[y]++;
order[x].push_back(y);
}
cin >> w;
for (int j = 1; j <= n; j++)
if (indegree[j] == 0) {
q.push(j);
totaltime[j] = times[j];
}
while (!q.empty()) {
int sz = q.size();
for (int j = 0; j < sz; j++) {
int x = q.front();
q.pop();
for (int k = 0; k < order[x].size(); k++) {
totaltime[order[x][k]] = max(totaltime[order[x][k]], totaltime[x]);
if (--indegree[order[x][k]] == 0) {
q.push(order[x][k]);
totaltime[order[x][k]] += times[order[x][k]];
}
}
}
}
cout << totaltime[w] << '\n';
}
}
예전에 풀어봤던 유형의 문제라 무난하게 해결했다.