| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 
 | #include<iostream>#include <vector>
 using namespace std;
 inline int read(){
 int x=0,f=1;char c=getchar();
 for(;!isdigit(c);c=getchar())if(c=='-')f=-1;
 for(;isdigit(c);c=getchar())x=(x<<3)+(x<<1)+(c^48);
 return x*f;
 }
 int n,m,d[26005],hav[10000005],cnt=0;
 int ans[26005];
 struct ro{
 int to;
 int val;
 };
 struct node{
 vector <ro> to;
 int size;
 int dis;
 int mx;
 bool usd;
 
 }tree[50005];
 int root;
 void getroot(int now,int fa){
 tree[now].size=1,tree[now].mx=0;
 for(auto i : tree[now].to){
 if(i.to==fa || tree[i.to].usd) continue;
 getroot(i.to,now);
 tree[now].size+=tree[i.to].size;
 tree[now].mx=max(tree[now].mx,tree[i.to].size);
 }
 tree[now].mx=max(tree[now].mx,tree[0].mx-tree[now].size);
 if(tree[now].mx<tree[root].mx) root=now;
 }
 
 void getdis(int now,int fa){
 d[++cnt]=tree[now].dis;
 for(auto i : tree[now].to){
 if(i.to==fa||tree[i.to].usd) continue;
 tree[i.to].dis=tree[now].dis+i.val;
 getdis(i.to,now);
 }
 }
 
 void calc(int now){
 hav[0]=1;
 vector<int>v;
 for(auto i : tree[now].to){
 if(tree[i.to].usd)continue;
 cnt=0;
 tree[i.to].dis=i.val;
 getdis(i.to,now);
 for(int j = 1;j<=cnt;j++){
 for(int k = 1;k<=m;k++){
 if(k>=d[j]) ans[k] |=hav[k-d[j]];
 }
 }
 for(int j = 1;j<=cnt;j++){
 if(d[j]<=1e7){
 hav[d[j]] =1;
 v.push_back(d[j]);
 }
 }
 }
 
 for(auto i:v){
 hav[i]=0;
 }
 }
 void divid(int now){
 calc(now);
 tree[now].usd=true;
 for(auto i : tree[now].to){
 if(!tree[i.to].usd){
 root=0;
 tree[0].mx=tree[i.to].size;
 getroot(i.to,0),getroot(root,0);
 divid(root);
 }
 }
 }
 int main(){
 n=read();
 int u,v,w;
 for(int i = 1;i<n;i++){
 u=read(),v=read(),w=read();
 tree[u].to.push_back((ro){v,w});
 tree[v].to.push_back((ro){u,w});
 }
 m=read();
 tree[0].mx=n;
 getroot(1,0),getroot(root,0);
 divid(root);
 long long sum=0;
 for(int i = 1;i<=m;i++) sum+=ans[i];
 cout<<sum;
 return 0;
 }
 
 
 |