# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
789953 | peteza | Parachute rings (IOI12_rings) | C++14 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
int N;
int cluster = 0;
int h[1000005];
int par[1000005];
bool vis[1000005];
bool inited = 0;
int cans = 0;
int deg[1000005], cmx;
vector<int> adj[1000005];
struct dat {
int ign = -1;
int deg[1000005] = {}, par[1000005];
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_) {
cmx = 0;
N = N_; inited = cans = 0;
elig.clear();
for(int i=0;i<=N;i++) adj[i].clear();
for(int i=0;i<=N;i++) h[i] = 0, par[i] = i;
}
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;
adj[A].push_back(B); adj[B].push_back(A);
++deg[A]; ++deg[B];
cmx = max(cmx, deg[A]);
cmx = max(cmx, deg[B]);
if(cmx >= 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
*/