← Home
#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;
}