Submission #503789

#TimeUsernameProblemLanguageResultExecution timeMemory
503789tabrIslands (IOI08_islands)C++17
90 / 100
1027 ms131076 KiB
#include <bits/stdc++.h> using namespace std; #ifdef tabr #include "library/debug.cpp" #else #define debug(...) #endif struct dsu { vector<int> p; vector<int> sz; int n; dsu(int _n) : n(_n) { p.resize(n); iota(p.begin(), p.end(), 0); sz.assign(n, 1); } inline int get(int x) { if (p[x] == x) { return x; } else { return p[x] = get(p[x]); } } inline bool unite(int x, int y) { x = get(x); y = get(y); if (x == y) { return false; } if (sz[x] > sz[y]) { swap(x, y); } p[x] = y; sz[y] += sz[x]; return true; } inline bool same(int x, int y) { return (get(x) == get(y)); } }; const int N = (int) 1e6 + 10; int l[N]; int nxt[N]; vector<int> vs[N]; long long dist[N]; long long max_dist[N]; bool cycle[N]; bool was[N]; vector<int> g[N]; int main() { ios::sync_with_stdio(false); cin.tie(0); int n; cin >> n; dsu uf(n); for (int i = 0; i < n; i++) { int j; cin >> j >> l[i]; j--; g[j].emplace_back(i); uf.unite(i, j); nxt[i] = j; } for (int i = 0; i < n; i++) { vs[uf.get(i)].emplace_back(i); } long long ans = 0; queue<int> que; deque<pair<int, long long>> deq; for (int i = 0; i < n; i++) { if (i != uf.get(i)) { continue; } int c = i; while (!was[c]) { was[c] = 1; c = nxt[c]; } int u = nxt[c]; cycle[c] = 1; vector<int> x(1, c); while (u != c) { cycle[u] = 1; x.emplace_back(u); u = nxt[u]; } vector<int> order; for (int j : x) { que.emplace(j); while (!que.empty()) { int v = que.front(); order.emplace_back(v); que.pop(); for (int to : g[v]) { if (cycle[to]) { continue; } dist[to] = dist[v] + l[to]; que.emplace(to); } } } long long t = 0; reverse(order.begin(), order.end()); for (int v : order) { max_dist[v] = max(max_dist[v], dist[v]); if (cycle[v]) { continue; } int to = nxt[v]; t = max(t, max_dist[to] + max_dist[v] - dist[to] * 2); max_dist[to] = max(max_dist[to], max_dist[v]); } deq.emplace_back(0, 0); long long y = l[c]; int sz = (int) x.size(); for (int jj = 1; jj < sz * 2; jj++) { int j = jj % sz; if (x[deq.front().first] == x[j]) { deq.pop_front(); } t = max(t, y + max_dist[x[j]] - deq.front().second); long long z = y - max_dist[x[j]]; while (!deq.empty() && deq.back().second >= z) { deq.pop_back(); } y += l[x[j]]; deq.emplace_back(j, z); } deq.clear(); ans += t; } cout << ans << '\n'; return 0; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...