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 "split.h"
#include <bits/stdc++.h>
using namespace std;
#define pb push_back
#define sz(a) (int)a.size()
#define all(a) begin(a),end(a)
using ll = long long;
using vi = vector<int>;
using ar2 = array<int,2>;
const int mxN = (int)1e5+3;
bitset<mxN> vis;
vector<ar2> edges;
int par[mxN], sub[mxN];
int cen, pick, pickPar;
int n, a, b, c, A, B, C;
vector<int> ans, adj[mxN];
int dfs(int s, int p){
sub[s] = 1; par[s]=p;
for(auto u : adj[s]){
if(u==p) continue;
sub[s]+=dfs(u,s);
}
return sub[s];
}
struct Dsu{
int p[mxN], sz[mxN];
void init(int n){
for(int i = 0; i < n; i++) p[i]=i,sz[i]=1;
}
int findSet(int i){ return p[i]==i?i:p[i]=findSet(p[i]); }
bool isSameSet(int i, int j) { return findSet(i)==findSet(j); }
void unionSet(int i, int j){
int x = findSet(i), y = findSet(j);
if(x==y) return;
if(sz[x]<sz[y])swap(x,y);
p[y]=x, sz[x]+=sz[y];
}
int findSz(int i){ return sz[findSet(i)]; }
} dsu;
void bfs(int s, int p, int d, int D){
queue<int> Q = queue<int>();
vis.reset(); Q.push(s); vis[s] = 1;
while(sz(Q)){
auto s = Q.front(); Q.pop();
if(d) ans[s]=D, d--;
for(auto u : adj[s]){
if(u==p) continue;
if(vis[u]) continue;
if(ans[u]!=C) continue;
vis[u] = 1; Q.push(u);
}
}
}
int fcen(int s, int p, int n){
for(auto u : adj[s]){
if(u==p) continue;
if(sub[u]>n/2) return fcen(u,s,n);
}
return s;
}
void dfs2(int s, int p){
if(p!=cen and s!=cen) dsu.unionSet(s,p);
for(auto u : adj[s]){
if(u==p) continue;
dfs2(u,s);
}
}
vi find_split(int N, int _a, int _b, int _c, vi p, vi q) {
n = N; a=_a, b=_b, c=_c; A=1,B=2,C=3; pick=-1;
if(a>b) { swap(a,b), swap(A,B); }
if(b>c) { swap(b,c), swap(B,C); }
if(a>b) { swap(a,b), swap(A,B); }
dsu.init(n); edges.clear();
for(int i = 0; i < sz(p); i++){
int x = p[i], y = q[i];
if(!dsu.isSameSet(x,y)){
adj[x].pb(y); adj[y].pb(x);
dsu.unionSet(x,y);
}
else edges.pb({x,y});
}
dfs(0,-1); cen = fcen(0,-1,n); dfs(cen,-1);
for(auto u : adj[cen]){
if(sub[u]<a) continue;
pick=u,pickPar=cen; break;
}
ans.clear(), ans.resize(n,C);
if(pick!=-1){
bfs(pick,pickPar,a,A);
bfs(pickPar,pick,b,B);
return ans;
}
dsu.init(n); for(auto u : adj[cen]) dfs2(u,cen);
for(auto [x,y] : edges){
adj[x].pb(y), adj[y].pb(x);
if(x==cen or y==cen) continue;
dsu.unionSet(x,y);
if(dsu.findSz(x)<a) continue;
bfs(x,cen,a,A); bfs(cen,-1,b,B); return ans;
}
for(auto &u : ans) u=0; return ans;
}
Compilation message (stderr)
split.cpp: In function 'vi find_split(int, int, int, int, vi, vi)':
split.cpp:110:2: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
110 | for(auto &u : ans) u=0; return ans;
| ^~~
split.cpp:110:26: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
110 | for(auto &u : ans) u=0; return ans;
| ^~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |