#include<bits/stdc++.h>
using namespace std;
int n,q;
struct edge{
int u,v,w;
}e[100005];
int vis[100005];
vector<int>g[100005];
vector<int>d[100005];
int dfs(int u,int fa){
vis[u]=1;
int sum=1;
for(int v:g[u]){
if(v==fa)continue;
sum+=dfs(v,u);
}
return sum;
}
void solve(int i){
long long ans=0;
for(int x:d[i]){
g[e[x].u].push_back(e[x].v);
g[e[x].v].push_back(e[x].u);
}
for(int j=1;j<=n;j++){
if(!vis[j]){
int sz=dfs(j,-1);
ans+=1ll*sz*(sz-1)/2;
}
}
printf("%lld\n",ans);
for(int x:d[i]){
g[e[x].u].clear(),g[e[x].v].clear();
vis[e[x].u]=0,vis[e[x].v]=0;
}
}
int main(){
scanf("%d%d",&n,&q);
for(int i=1;i<n;i++){
scanf("%d%d%d",&e[i].u,&e[i].v,&e[i].w);
for(int j=1;j<=e[i].w/j;j++){
if(e[i].w%j==0){
d[j].push_back(i);
if(j!=e[i].w/j)d[e[i].w/j].push_back(i);
}
}
}
while(q--){
int d;scanf("%d",&d);
solve(d);
}
}