Submission #736799

#TimeUsernameProblemLanguageResultExecution timeMemory
736799bobthebuilderSplit the Attractions (IOI19_split)C++17
40 / 100
97 ms16908 KiB
#include "split.h" #include<bits/stdc++.h> using namespace std; #define sz(x) (int)x.size() #define REP(i,n) for(int i=0;i<n;i++) #define REP1(i,n) for(int i=1;i<=n;i++) #define pb push_back #define lowb(x) (x&(-x)) #define ALL(_x) _x.begin(),_x.end() #define pii pair<int,int> #define f first #define s second #define SORT_UNIQUE(x) sort(ALL(x)),x.erase(unique(ALL(x)),x.end()) const int maxn=1e5+5; #define ll long long vector<int> v[maxn]; bool vis[maxn]; vector<int> top; void dfs(int u){ top.pb(u); vis[u]=1; for(int x:v[u]){ if(!vis[x]) dfs(x); } } int sz[maxn],par[maxn]; void dfs(int u,int p){ sz[u]=1; par[u]=p; for(int x:v[u]){ if(x==p) continue; dfs(x,u); sz[u]+=sz[x]; } } vector<int> val; bool cmp(int a,int b){ return val[a-1]<val[b-1]; } vector<int> find_split(int n, int a, int b, int c, vector<int> p, vector<int> q) { vector<int> ans(n,0); REP(i,sz(p)){ v[p[i]].pb(q[i]),v[q[i]].pb(p[i]); } val={a,b,c}; vector<int> asd={1,2,3}; sort(ALL(asd),cmp); sort(ALL(val)); if(sz(p)==n-1){ dfs(0,-1); int mn=0; REP(i,n){ if(sz[i]>=val[0] and sz[i]<sz[mn]) mn=i; } if(n-sz[mn]<val[0]){ return ans; } if(n-sz[mn]<sz[mn]){ swap(val[0],val[1]),swap(asd[0],asd[1]); } vis[par[mn]]=1; dfs(mn); REP(i,val[0]) ans[top[i]]=asd[0]; top.clear(); vis[par[mn]]=0; dfs(par[mn]); REP(i,val[1]) ans[top[i]]=asd[1]; REP(i,n) if(!ans[i]) ans[i]=asd[2]; } else{ dfs(0); REP(i,a) ans[top[i]]=1; REP(i,b) ans[top[i+a]]=2; REP(i,c) ans[top[i+a+b]]=3; } return ans; }
#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...