# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
937170 | amirhoseinfar1385 | Harbingers (CEOI09_harbingers) | C++11 | 159 ms | 44144 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
const int maxn=100000+10;
long long inf=1e18,kaf=(1<<16),sor,makh;
struct func{
func(){
fas=shib=0;
}
long long fas;
int shib;
long long inersect(func f){
sor=fas-f.fas,makh=f.shib-shib;
if(makh==0){
if(sor>0){
return -inf;
}
return inf;
}
if(makh<0){
makh*=-1;
sor*=-1;
}
if(sor<0){
return sor/makh;
}
return (sor+makh-1)/makh;
}
bool operator <(const func f)const {
return shib<f.shib;
}
}fakefunc;
struct cht{
vector<pair<long long,func>>st;
void add(func f){
while((int)st.size()>0){
long long x=f.inersect(st.back().second);
if(x<=st.back().first){
st.pop_back();
continue;
}else{
st.emplace_back(make_pair(x,f));
break;
}
}
if((int)st.size()==0){
st.emplace_back(make_pair(-inf,f));
}
}
long long get(long long x){
int p=lower_bound(st.begin(),st.end(),make_pair(x+1,fakefunc))-st.begin()-1;
if(p<0){
return -inf;
}
return st[p].second.fas+x*st[p].second.shib;
}
};
long long ret;
struct segment{
cht ch[(1<<17)];
void upd(int i,int l,int r,int tl,int tr,func f){
if(l>r||l>tr||r<tl||tl>tr){
return ;
}
if(l>=tl&&r<=tr){
ch[i].add(f);
return ;
}
int m=(l+r)>>1;
upd((i<<1),l,m,tl,tr,f);
upd((i<<1)^1,m+1,r,tl,tr,f);
}
void pors(int x,int v){
ret=-inf;
x+=kaf;
while(x>0){
ret=max(ret,ch[x].get(v));
x>>=1;
}
}
}seg;
struct yal{
int u,v,w;
int getad(int fu){
return (u^v^fu);
}
}alle[maxn];
int n,timea=-1,high[maxn];
long long dp[maxn];
pair<int,int>stf[maxn],all[maxn];
vector<int>adj[maxn];
void dfs(int u,int par=0,int len=0){
if((int)adj[u].size()==1&&u!=1){
timea++;
stf[u].first=timea;
}else{
stf[u].first=timea+1;
}
high[u]=len;
for(auto x:adj[u]){
int v=alle[x].getad(u);
if(v!=par){
dfs(v,u,len+alle[x].w);
}
}
stf[u].second=timea;
}
void vorod(){
cin>>n;
for(int i=0;i<n-1;i++){
cin>>alle[i].u>>alle[i].v>>alle[i].w;
adj[alle[i].u].push_back(i);
adj[alle[i].v].push_back(i);
}
for(int i=2;i<=n;i++){
cin>>all[i].first>>all[i].second;
}
}
void pre(){
dfs(1);
}
void upd(int u){
seg.pors(stf[u].first,all[u].second);
dp[u]=1ll*min(-ret,0ll)+all[u].first+1ll*all[u].second*high[u];
func f;
f.fas=-dp[u];
f.shib=high[u];
seg.upd(1,0,kaf-1,stf[u].first,stf[u].second,f);
}
void solve(int u=1,int para=0){
upd(u);
for(auto x:adj[u]){
int v=alle[x].getad(u);
if(v!=para){
solve(v,u);
}
}
}
void khor(){
for(int i=2;i<=n;i++){
cout<<dp[i]<<" ";
}
cout<<"\n";
}
int main(){
ios::sync_with_stdio(0);
cin.tie(0);
vorod();
pre();
solve();
khor();
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |