P5908,0pts
#include<bits/stdc++.h>
using namespace std;
int n,d,t[100005],vis[100005],ans=0;
void dfs(int num,int dep){
vis[num]=1;
if(dep==d) return;
for(int i=1;i<=n;i++){
if(!vis[i]&&t[i]==num){
ans++;
dfs(i,dep+1);
}
}
}
int main(){
int x,y;
cin>>n>>d;
for(int i=1;i<n;i++){
cin>>x>>y;
t[y]=x;
}
dfs(1,0);
cout<<ans;
return 0;
}