This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
typedef int64_t llo;
#define mp make_pair
#define pb push_back
#define a first
#define b second
int n,m;
int ac,bc,dd;
int par[100001][20];
int lev[100001];
vector<int> adj[100001];
int co=0;
int st[100001];
int en[100001];
int dp[100001];
int tree[400001];
int lazy[400001];
vector<pair<pair<int,int>,pair<int,int>>> pre[100001];
vector<int> pre2[100001];
void update(int no,int l,int r,int aa,int bb,int val){
if(lazy[no]!=0){
tree[no]+=lazy[no];
if(l<r){
lazy[no*2+1]+=lazy[no];
lazy[no*2+2]+=lazy[no];
}
lazy[no]=0;
}
if(r<aa or l>bb){
return;
}
if(aa<=l and r<=bb){
tree[no]+=val;
if(l<r){
tree[no*2+1]+=val;
tree[no*2+2]+=val;
}
}
else{
int mid=(l+r)/2;
update(no*2+1,l,mid,aa,bb,val);
update(no*2+2,mid+1,r,aa,bb,val);
tree[no]=tree[no*2+1]+tree[no*2+2];
}
}
int query(int no,int l,int r,int i){
if(lazy[no]!=0){
tree[no]+=lazy[no];
if(l<r){
lazy[no*2+1]+=lazy[no];
lazy[no*2+2]+=lazy[no];
}
lazy[no]=0;
}
if(l==r){
return tree[no];
}
int mid=(l+r)/2;
if(i<=mid){
return query(no*2+1,l,mid,i);
}
else{
return query(no*2+2,mid+1,r,i);
}
}
int dfs(int no,int par2=-1,int levv=0){
st[no]=co;
co+=1;
par[no][0]=par2;
lev[no]=levv;
for(auto j:adj[no]){
if(j==par2){
continue;
}
dfs(j,no,levv+1);
}
en[no]=co-1;
}
int kk(int aa,int k){
for(int j=19;j>=0;j--){
if((1<<j)&k){
aa=par[aa][j];
}
}
return aa;
}
pair<int,pair<int,int>> lca(int aa,int bb){
int cc,dd;
cc=aa;
dd=bb;
if(lev[aa]>lev[bb]){
aa=kk(aa,abs(lev[bb]-lev[aa]));
if(aa==bb){
return {aa,{kk(cc,abs(lev[bb]-lev[cc])-1),-1}};
}
}
else{
bb=kk(bb,abs(lev[bb]-lev[aa]));
if(aa==bb){
return {aa,{-1,kk(dd,abs(lev[bb]-lev[dd])-1)}};
}
}
for(int j=19;j>=0;j--){
if(par[aa][j]!=par[bb][j]){
aa=par[aa][j];
bb=par[bb][j];
}
}
return {par[aa][0],{kk(cc,abs(lev[cc]-lev[par[aa][0]])-1),kk(dd,abs(lev[dd]-lev[par[aa][0]])-1)}};
}
int dfs2(int no,int par2=-1){
int su=0;
for(auto j:adj[no]){
if(j!=par2){
dfs2(j,no);
su+=dp[j];
}
}
dp[no]=su;
for(int j=0;j<pre[no].size();j++){
pair<pair<int,int>,pair<int,int>> kk=pre[no][j];
int cost=pre2[no][j];
if(kk.b.a==-1){
cost+=su;
cost-=dp[kk.b.b];
cost+=query(0,0,n-1,st[kk.a.b]);
}
else if(kk.b.b==-1){
cost+=su;
cost-=dp[kk.b.a];
cost+=query(0,0,n-1,st[kk.a.a]);
}
else{
cost+=su;
cost-=dp[kk.b.b];
cost-=dp[kk.b.a];
cost+=query(0,0,n-1,st[kk.a.b]);
cost+=query(0,0,n-1,st[kk.a.a]);
}
dp[no]=max(dp[no],cost);
}
update(0,0,n-1,st[no],st[no],su);
for(auto j:adj[no]){
if(j==par2){
continue;
}
update(0,0,n-1,st[j],en[j],su-dp[j]);
}
}
int main(){
memset(tree,0,sizeof(tree));
memset(lazy,0,sizeof(lazy));
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin>>n;
for(int i=0;i<n-1;i++){
cin>>ac>>bc;
adj[ac-1].pb(bc-1);
adj[bc-1].pb(ac-1);
}
dfs(0);
cin>>m;
for(int j=1;j<20;j++){
for(int i=0;i<n;i++){
if(par[i][j-1]==-1){
par[i][j]=-1;
}
else{
par[i][j]=par[par[i][j-1]][j-1];
}
}
}
for(int i=0;i<m;i++){
cin>>ac>>bc>>dd;
pair<int,pair<int,int>> cc=lca(ac-1,bc-1);
pre[cc.a].pb({{ac-1,bc-1},{cc.b}});
pre2[cc.a].pb(dd);
// cout<<cc.a<<","<<cc.b.a<<","<<cc.b.b<<endl;
}
dfs2(0);
cout<<dp[0]<<endl;
return 0;
}
Compilation message (stderr)
election_campaign.cpp: In function 'int dfs(int, int, int)':
election_campaign.cpp:79:1: warning: no return statement in function returning non-void [-Wreturn-type]
}
^
election_campaign.cpp: In function 'int dfs2(int, int)':
election_campaign.cpp:121:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int j=0;j<pre[no].size();j++){
~^~~~~~~~~~~~~~~
election_campaign.cpp:151:1: warning: no return statement in function returning non-void [-Wreturn-type]
}
^
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |