#include <iostream>
using namespace std;
int bruh;
int par[2000];
int siz[2000];
int cnt[1600][1600];
int fin(int x){
if(par[x]==x){return x;}
else {return fin(par[x]);}
}
void unite(int x, int y){
int xr = fin(x);
int yr = fin(y);
if(siz[xr]<siz[yr]){swap(xr, yr);}
par[yr] = xr;
siz[xr] += siz[yr];
}
void initialize(int du){
bruh = du;
for(int i=1; i<=du; i++){
par[i] = i; siz[i] = 1;
}
for(int i=1; i<=du; i++){
for(int j=1; j<=du; j++){
cnt[i][j] = 0;
}
}
}
int hasEdge(int x, int y){
x++; y++;
int n1 = fin(x);
int n2 = fin(y);
int n3 = siz[n1];
int n4 = siz[n2];
if(cnt[n1][n2] == n3 * n4 - 1){
unite(n1, n2);
cnt[n1][n2]++;
cnt[n2][n1]++;
if(n3<n4){
swap(n1, n2);
}
for(int i=1; i<=bruh; i++){
cnt[i][n1] += cnt[i][n2];
cnt[n1][i] += cnt[n2][i];
}
return 1;
}
else {
cnt[n1][n2]++;
cnt[n2][n1]++;
return 0;
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |