# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
497729 | S2speed | 공장들 (JOI14_factories) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#include<factories.h>
using namespace std;
#pragma GCC optimize ("Ofast")
#define all(x) x.begin() , x.end()
#define sze(x) (ll)(x.size())
#define mp(x , y) make_pair(x , y)
#define wall cerr<<"--------------------------------------"<<endl
typedef long long int ll;
typedef pair<ll , ll> pll;
typedef pair<int , int> pii;
typedef long double db;
typedef pair<pll , ll> plll;
typedef pair<int , pii> piii;
typedef pair<pll , pll> pllll;
const ll maxn = 5e5 + 16 , md = 1e9 + 7 , inf = 2e16;
ll n;
vector<pll> adj[maxn] , s , r;
vector<ll> v , vdj[maxn];
bitset<maxn> bl , rd;
ll jad[maxn][20] , dis[maxn] , dep = 0 , st[maxn] , ft[maxn] , tme = 0 , ps[maxn] , sum = 0 , bc[maxn] , rc[maxn];
void pDFS(ll r , ll par){
st[r] = tme++;
dis[r] = dep++;
ps[r] = sum;
jad[r][0] = par;
for(auto p : adj[r]){
ll i = p.first , w = p.second;
if(i == par) continue;
sun += w;
pDFS(i , r);
sum -= w;
}
ft[r] = tme;
dep--;
return;
}
ll find_jad(ll v , ll d){
d = dis[v] - d;
for(ll j = 0 ; j < 20 ; j++){
if(d & (1 << j)) v = jad[v][j];
}
return v;
}
ll lca(ll v , ll u){
if(dis[v] > dis[u]) swap(v , u);
u = find_jad(u , dis[v]);
if(v == u) return v;
for(ll j = 19 ; j >= 0 ; j--){
if(jad[v][j] != jad[u][j]){
v = jad[v][j];
u = jad[u][j];
}
}
return jad[v][0];
}
void Init(int N , int v[] , int u[] , int w[]){
memset(jad , -1 , sizeof(jad));
n = N;
for(ll i = 0 ; i < n - 1 ; i++){
v[i]--; u[i]--;
adj[v[i]].push_back({u[i] , w[i]});
adj[u[i]].push_back({v[i] , w[i]});
}
pDFS(0 , -1);
return;
}
void cDFS(ll r){
for(auto i : vdj[r]){
cDFS(i);
rc[r] = min(rc[r] , rc[i]);
bc[r] = min(bc[r] , bc[i]);
}
if(rd[r]){
rc[r] = ps[r];
}
if(bl[r]){
bc[r] = ps[r];
}
return;
}
ll Query(int k1 , vector<int> v1 , int k2 , vector<int> v2){
s.clear(); r.clear(); v.clear();
for(ll e = 0 ; e < k1 ; e++){
ll i = v1[e];
s.push_back({st[i] , i});
bl[i] = true;
}
for(ll e = 0 ; e < k2 ; e++){
ll i = v2[e];
s.push_back({st[i] , i});
rd[i] = true;
}
sort(all(s)); r = s;
ll sz = sze(s);
for(ll e = 1 ; e < vs ; e++){
ll i = s[e].second , j = s[e - 1].second , l = lca(i , j);
r.push_back({st[l] , l});
}
sort(all(r));
r.resize(distance(r.begin() , unique(all(r))));
ll rs = sze(r);
for(ll e = 0 ; e < rs ; e++){
ll i = r[e].second , pr = -1;
while(!v.empty()){
ll u = v.back();
if(st[u] < st[i] && ft[i] <= ft[u]){
pr = u;
break;
}
v.pop_back();
}
if(pr != -1) vdj[pr].push_back(i);
v.push_back(i);
}
cDFS(v[0]);
ll res = inf;
for(ll e = 0 ; e < rs ; e++){
ll i = r[e].second;
res = min(res , bc[i] + rc[i] - 2ll * ps[i]);
bc[i] = rc[i] = inf;
bl[i] = rd[i] = false;
vdj[i].clear();
}
return res;
}