标签:tor long lin color span read 接下来 oid targe
时间限制:1秒
空间限制:32768K
第一行一个整数n (1 ≤ n ≤ 10^5) 接下来n-1行,每行一个整数,依次为2号点到n号点父亲的编号。 最后一行n个整数为k[i] (1 ≤ k[i] ≤ 10^5) 样例解释: 对节点3操作,导致节点2与节点3变黑 对节点4操作,导致节点4变黑 对节点1操作,导致节点1变黑
一个数表示最少操作次数
4 1 2 1 1 2 2 1
3
1 #include<bits/stdc++.h> 2 using namespace std; 3 const int N =166666; 4 typedef long long ll; 5 vector<ll> T[N]; 6 ll n,a[N]; 7 struct Tree 8 { 9 ll ans; 10 ll maxn; 11 ll Gmaxn; 12 }; 13 inline ll read() 14 { 15 ll x=0,f=1; 16 char ch=getchar(); 17 while(ch<‘0‘||ch>‘9‘) 18 { 19 if(ch==‘-‘) 20 f=-1; 21 ch=getchar(); 22 } 23 while(ch>=‘0‘&&ch<=‘9‘) 24 { 25 x=x*10+ch-‘0‘; 26 ch=getchar(); 27 } 28 return x*f; 29 } 30 inline void write(ll x) 31 { 32 if(x<0) 33 { 34 putchar(‘-‘); 35 x=-x; 36 } 37 if(x>9) 38 { 39 write(x/10); 40 } 41 putchar(x%10+‘0‘); 42 } 43 Tree DFS(ll xx,ll yy) 44 { 45 Tree ret={0,0,0}; 46 ll sum1=0,sum2=-1,sum3=-1; 47 for(ll i=0;i<T[xx].size();i++) 48 { 49 ll to=T[xx][i]; 50 if(to==yy) 51 continue; 52 ret=DFS(to,xx); 53 sum1+=ret.ans; 54 sum2=max(ret.maxn,sum2); 55 sum3=max(ret.Gmaxn,sum3); 56 } 57 if(sum2<=-1) 58 { 59 sum2=max(a[xx],sum3); 60 sum1+=1; 61 } 62 sum3=max(sum3,a[xx]); 63 ret.ans=sum1; 64 ret.maxn=sum2-1; 65 ret.Gmaxn=sum3-1; 66 return ret; 67 } 68 int main() 69 { 70 ll p; 71 n=read(); 72 for(ll i=1;i<=n-1;i++) 73 { 74 p=read(); 75 T[p].push_back(i+1); 76 } 77 for(ll i=1;i<=n;i++) 78 { 79 a[i]=read(); 80 a[i]--; 81 } 82 write(DFS(1,0).ans); 83 return 0; 84 }
CodeM美团点评编程大赛初赛B轮 黑白树【DFS深搜+暴力】
标签:tor long lin color span read 接下来 oid targe
原文地址:http://www.cnblogs.com/ECJTUACM-873284962/p/7096578.html