Submission #789944

#TimeUsernameProblemLanguageResultExecution timeMemory
789944petezaParachute rings (IOI12_rings)C++14
20 / 100
79 ms16284 KiB
#include <bits/stdc++.h> using namespace std; int N; int cluster = 0; int role[200005]; int h[200005]; int par[200005]; bool vis[200005]; bool inited = 0; int cans = 0; vector<int> adj[200005]; set<pair<int, int>> S; struct dat { int ign = -1; int deg[200005] = {}, par[200005]; bool cool = 1; int fpar(int x) { return x == par[x] ? x : par[x] = fpar(par[x]); } dat (int x) { ign = x; for(int i=0;i<N;i++) par[i] = i; for(int i=0;i<N;i++) { if(i == ign) continue; for(int e:adj[i]) { if(e != ign) { deg[i]++; par[fpar(i)] = fpar(e); }; } if(deg[i] >= 3) { cool = 0; return ; } } } void upd(int a, int b) { if(a == ign || b == ign) return; deg[a]++; deg[b]++; if(deg[a] >= 3 || deg[b] >= 3) cool = 0; if(fpar(a) == fpar(b)) cool = 0; par[fpar(a)] = fpar(b); } }; vector<dat> elig; int mg(int x, int y) { if(h[x] < h[y]) return par[x] = y; if(h[x] == h[y]) h[x]++; return par[y] = x; } int fpar(int x) { return x == par[x] ? x : fpar(par[x]); } void Init(int N_) { N = N_; inited = 0; elig.clear(); for(int i=0;i<=N;i++) adj[i].clear(); for(int i=0;i<N;i++) S.emplace(0, i); for(int i=0;i<=N;i++) h[i] = 0, par[i] = i; memset(role, 0, sizeof role); } void dfs(int a) { if(vis[a]) return ; vis[a] = 1; cans++; for(int e:adj[a]) dfs(e); } void Link(int A, int B) { if(cluster >= 2) return; S.erase({adj[A].size(), A}); S.erase({adj[B].size(), B}); adj[A].push_back(B); adj[B].push_back(A); S.emplace(adj[A].size(), A); S.emplace(adj[B].size(), B); //for(auto e:S) cout << e.first << ' ' << e.second << '\n'; //cout << (--S.end())->first << '\n'; if((--S.end())->first >= 3) { //initialize if(!inited) { inited = 1; auto e = *(--S.end()); for(auto E:adj[e.second]) { dat neu(E); if(neu.cool) elig.emplace_back(neu); } dat neu(e.second); if(neu.cool) elig.emplace_back(neu); } else { for(auto it = elig.begin(); it != elig.end(); it++) { auto &e = *it; e.upd(A, B); if(e.cool) continue; elig.erase(it--); } } cans = elig.size(); return; } int pA = fpar(A), pB = fpar(B); if(pA == pB) { cluster++; memset(vis, 0, sizeof vis); dfs(A); } else { int res = mg(pA, pB); } } int CountCritical() { if(cluster >= 2) return 0; if(inited) return cans; if(!cluster) return N; //cluster count is equal to 1 return cans; } /* 7 13 -1 1 2 -1 0 5 -1 2 0 -1 3 2 -1 3 5 -1 4 3 -1 */

Compilation message (stderr)

rings.cpp: In function 'void Link(int, int)':
rings.cpp:114:9: warning: unused variable 'res' [-Wunused-variable]
  114 |     int res = mg(pA, pB);
      |         ^~~
#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...