Submission #57246

#TimeUsernameProblemLanguageResultExecution timeMemory
57246PeppaPigIslands (IOI08_islands)C++14
31 / 100
392 ms68368 KiB
#include <bits/stdc++.h> #define pll pair<long long, long long> #define x first #define y second using namespace std; const int N = 1e6 + 5; int n; pll par[N], dp[N]; long long dm[N], ans; int deg[N]; bitset<N> vis; int main() { scanf("%d", &n); for(int i = 1; i <= n; i++) { long long v, w; scanf("%lld%lld", &v, &w); par[i] = pll(v, w); deg[v]++; } queue<int> Q; for(int i = 1; i <= n; i++) if(!deg[i]) Q.emplace(i); while(!Q.empty()) { int now = Q.front(); Q.pop(); dm[now] = max(dm[now], dp[now].x + dp[now].y); dm[par[now].x] = max(dm[par[now].x], dm[now]); long long dis = dp[now].x + par[now].y; if(dis > dp[par[now].x].x) swap(dis, dp[par[now].x].x); if(dis > dp[par[now].x].y) swap(dis, dp[par[now].x].y); if(!--deg[par[now].x]) Q.emplace(par[now].x); } for(int k = 1; k <= n; k++) if(!vis[k] && deg[k]) { int p = k; vector<pll> cyc; deque<pll> Q; while(!vis[p]) { vis[p] = true; dm[p] = max(dm[p], dp[p].x + dp[p].y); cyc.emplace_back(p, par[p].y); p = par[p].x; } long long ret = 0, dis = cyc[0].y; for(int i = 1; i <= n; i++) ret = max(ret, max(dp[ret].x, dm[ret])); for(int i = 1; i < cyc.size(); i++) { while(!Q.empty() && Q.back().x < dis + dp[cyc[i].x].x + dp[cyc[0].x].x) Q.pop_back(); Q.emplace_back(dis + dp[cyc[i].x].x + dp[cyc[0].x].x, i); dis += cyc[i].y; } ret = max(ret, Q.front().x); for(int i = 0; i < cyc.size() - 1; i++) { dis -= cyc[i].y; while(!Q.empty() && Q.front().y <= i + 1) Q.pop_front(); while(!Q.empty() && Q.back().x < dis + dp[cyc[i].x].x + dp[cyc[i + 1].x].x) Q.pop_back(); Q.emplace_back(dis + dp[cyc[i].x].x + dp[cyc[i + 1].x].x, i); dis += cyc[i].y; ret = max(ret, Q.front().x); } ans += ret; } printf("%lld", ans); return 0; }

Compilation message (stderr)

islands.cpp: In function 'int main()':
islands.cpp:50:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int i = 1; i < cyc.size(); i++) {
                  ~~^~~~~~~~~~~~
islands.cpp:56:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int i = 0; i < cyc.size() - 1; i++) {
                  ~~^~~~~~~~~~~~~~~~
islands.cpp:18:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d", &n);
  ~~~~~^~~~~~~~~~
islands.cpp:21:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%lld%lld", &v, &w);
   ~~~~~^~~~~~~~~~~~~~~~~~~~
#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...