Submission #285249

#TimeUsernameProblemLanguageResultExecution timeMemory
285249YJUFactories (JOI14_factories)C++14
0 / 100
8021 ms167172 KiB
#include<bits/stdc++.h> #include "factories.h" #pragma GCC optimize("unroll-loops,no-stack-protector") using namespace std; typedef long long ll; typedef long double ld; typedef pair<int,ll> pll; const ll MOD=1e9+7; const ll MOD2=998244353; const ll N=5e5+5; const ld pi=3.14159265359; const ll INF=(1LL<<60); #define SQ(i) ((i)*(i)) #define REP(i,n) for(ll i=0;i<n;i++) #define REP1(i,n) for(ll i=1;i<=n;i++) #define pb push_back #define mp make_pair #define X first #define Y second #define setp setprecision #define lwb lower_bound #define SZ(_a) (ll)_a.size() int parent[N],sz[N],ms[N],lv[N],K,lis[N]; vector<pll> v[N]; ll dist[N][25],dis[N]; void buildd(int nd,int pa,int L){ for(auto i:v[nd]){ if(i.X==pa||lv[i.X]!=-1)continue; dist[i.X][L]=i.Y+dist[nd][L]; buildd(i.X,nd,L); } } void DFS(int id,int par){ sz[id]=1;ms[id]=0; for(pll i:v[id]){ if(i.X==par||lv[i.X]!=-1)continue; DFS(i.X,id); sz[id]+=sz[i.X]; } for(pll i:v[id]){ if(i.X==par||lv[i.X]!=-1)continue; ms[id]=max(ms[id],sz[i.X]); } lis[K++]=id; } void buildc(int nd,int pa){ K=0; DFS(nd,0); ll cho=lis[0]; REP(i,K){ if(max(ms[cho],sz[nd]-sz[cho])>max(ms[lis[i]],sz[nd]-ms[lis[i]]))cho=lis[i]; } parent[cho]=pa; lv[cho]=lv[pa]+1; buildd(cho,0,lv[cho]); for(auto i:v[cho]){ if(lv[i.X]!=-1||i.X==pa)continue; buildc(i.X,cho); } } void Init(int n,int A[],int B[],int D[]){ REP1(i,n)dis[i]=INF; REP(i,n-1){ v[B[i]+1].pb(mp(A[i]+1,D[i])); v[A[i]+1].pb(mp(B[i]+1,D[i])); } memset(lv,-1,sizeof(lv)); buildc(1,0); } ll Query(int S,int x[],int T,int y[]){ ll ans=INF; REP(i,S){ ll nd=x[i]+1; while(nd){ dis[nd]=min(dis[nd],dist[x[i]+1][lv[nd]]); nd=parent[nd]; } } REP(i,T){ ll nd=y[i]+1; while(nd){ ans=min(ans,dis[nd]+dist[y[i]+1][lv[nd]]); nd=parent[nd]; } } REP(i,S){ ll nd=x[i]+1; while(nd){ dis[nd]=INF; nd=parent[nd]; } } return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...