白駿1005 ACM Craft
13032 ワード
白駿1005 ACM Craft
リンク:https://www.acmicpc.net/problem/1005
質問する
キー(Key)
◆位相ソートにより、特定の建築xを建造するための先行建築経路のうち、最長時間の経路の時間をtotatime[x]に入れる.
建物を建てることができる場合(indgree[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';
}
}
追加
以前に解決したタイプの問題だったので、スムーズに解決できました.
Reference
この問題について(白駿1005 ACM Craft), 我々は、より多くの情報をここで見つけました https://velog.io/@bgg01578/백준-1005-ACM-Craftテキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol