Submission #834687

#TimeUsernameProblemLanguageResultExecution timeMemory
834687FEDIKUSFireworks (APIO16_fireworks)C++17
0 / 100
11 ms21460 KiB
#include<bits/stdc++.h> using namespace std; using ll = long long; using pii = pair<ll,ll>; const ll maxn=3e5+10; vector<pii> g[maxn]; multiset<ll> slope[maxn]; void dfs(ll node,ll c=-1){ for(auto i:g[node]){ dfs(i.first,i.second); } pair<ll,ll> maxi={-1,-1}; for(auto i:g[node]){ maxi=max(maxi,{ll(slope[i.first].size()),i.first}); } if(maxi.first!=-1){ swap(slope[maxi.second],slope[node]); for(auto i:g[node]){ if(i.first==maxi.second) continue; for(ll j:slope[i.first]){ slope[node].emplace(j); } auto it=slope[node].end(); it--; slope[node].erase(it); } } if(slope[node].empty()){ slope[node].emplace(c); slope[node].emplace(c); return; } if(c!=-1){ auto it=--slope[node].end(); ll posl=*it+c; slope[node].erase(it); it=--slope[node].end(); ll predposl=*it+c; slope[node].erase(it); slope[node].emplace(posl); slope[node].emplace(predposl); } } int main(){ ll n,m; cin>>n>>m; n+=m; ll vr=0; for(ll i=2;i<=n;i++){ ll p,c; cin>>p>>c; g[p].push_back({i,c}); vr+=c; } dfs(1); ll sl=0; vector<ll> nes; for(ll i:slope[1]) nes.push_back(i); reverse(nes.begin(),nes.end()); nes.push_back(0); for(ll i=1;i<ll(nes.size());i++){ vr-=sl*(nes[i-1]-nes[i]); sl++; } cout<<vr; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...