#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
vector<int>g[N];
int cnt[N];
vector<int>dp[N],f[N];
void dfs(int u,int fa){
int mx=0;
for(int v:g[u]){
if(v==fa) continue;
cnt[u]++,dfs(v,u);
mx=max(mx,(int)f[v].size());
}
dp[u].resize(mx,cnt[u]);
for(int v:g[u]){
if(v==fa) continue;
for(int j=0;j<f[v].size();j++) dp[u][j]+=f[v][j]-1;
}
for(int i=0;;i++){
int mid=(i<mx?dp[u][i]:cnt[u]);
if(mid-i<=1) break;
f[u].push_back(mid-i);
}
}
int main(){
ios::sync_with_stdio(false),cin.tie(NULL),cout.tie(0);
int n,q;cin>>n;
for(int i=1;i<n;i++){
int u,v;cin>>u>>v;
g[u].push_back(v),g[v].push_back(u);
}
dfs(1,0);
cin>>q;
while(q--){
int u,w;cin>>u>>w;
if(dp[u].size()>w) cout<<dp[u][w]<<"\n";
else cout<<cnt[u]<<"\n";
}
return 0;
}