제출 #1107872

#제출 시각아이디문제언어결과실행 시간메모리
1107872stdfloatEvacuation plan (IZhO18_plan)C++17
100 / 100
356 ms40636 KiB
#include <bits/stdc++.h> using namespace std; using ll = long long; #define all(v) (v).begin(), (v).end() #define ff first #define ss second #define pii pair<int, int> vector<int> p, sz, ans; vector<vector<pii>> G; vector<vector<int>> dsu; void uni(int x, int y, int d) { x = p[x]; y = p[y]; if (x == y) return; if (sz[x] > sz[y]) swap(x, y); dsu[y].insert(dsu[y].end(), all(dsu[x])); for (auto i : dsu[x]) { p[i] = y; for (auto [j, k] : G[i]) { if (p[j] == y && ans[k] == -1) ans[k] = d; } } dsu[x].clear(); sz[y] += sz[x]; sz[x] = 0; } int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int n, m; cin >> n >> m; vector<pii> E[n]; while (m--) { int x, y, w; cin >> x >> y >> w; x--; y--; E[x].push_back({y, w}); E[y].push_back({x, w}); } int k; cin >> k; vector<int> dis(n, INT_MAX); priority_queue<pii> q; while (k--) { int x; cin >> x; x--; dis[x] = 0; q.push({0, x}); } while (!q.empty()) { auto [d, x] = q.top(); d = -d; q.pop(); if (d != dis[x]) continue; for (auto [i, w] : E[x]) { if (d + w < dis[i]) { dis[i] = d + w; q.push({-dis[i], i}); } } } vector<int> ord(n); iota(all(ord), 0); sort(all(ord), [&](int x, int y) { return dis[x] > dis[y]; }); int Q; cin >> Q; G.assign(n, {}); ans.assign(Q, -1); for (int i = 0; i < Q; i++) { int x, y; cin >> x >> y; x--; y--; G[x].push_back({y, i}); G[y].push_back({x, i}); } p.assign(n, -1); sz.assign(n, 1); dsu.assign(n, {}); for (auto i : ord) { if (p[i] == -1) { p[i] = i; dsu[i] = {i}; } for (auto [j, w] : E[i]) if (p[j] != -1) uni(i, j, dis[i]); } for (auto i : ans) cout << i << '\n'; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...