zhao_ry514114
赵若伊

导航

 
#include<bits/stdc++.h>
using namespace std;
const int N=500005;
int n,m,s,a,b,f[N][22],dep[N];
vector<int> g[N];
void dfs(int u,int p,int d){
	f[u][0]=p;
	dep[u]=d; 
	int sz=g[u].size();
	for(int i=0;i<sz;i++){
		int v=g[u][i];
		if(v==p) continue;
		dfs(v,u,d+1);
	}
} 
int lca(int x,int y){
	if(dep[x]<dep[y]) swap(x,y);
	for(int i=log2(dep[x]-dep[y]);i>=0;i--){
		if((1<<i)<=dep[x]-dep[y]) x=f[x][i];
	}
	assert(dep[x]==dep[y]);
	if(x==y) return x;
	for(int i=log2(dep[x]);i>=0;i--){
		if(f[x][i]!=f[y][i]){
			x=f[x][i];
			y=f[y][i];
		}
	}
	 assert(x!=y&&f[x][0]==f[y][0]);
	return f[x][0];
} 
int main(){
	cin>>n>>m>>s;
	for(int i=1;i<n;i++){
		cin>>a>>b;
		g[a].push_back(b);
		g[b].push_back(a);
	}
	dfs(s,s,0);
	for(int i=1;i<22;i++){
		for(int u=1;u<=n;u++)
			f[u][i]=f[f[u][i-1]][i-1];		
	}
	while(m--){
		cin>>a>>b;
		cout<<lca(a,b)<<endl;
	}
	return 0;
}
posted on 2025-08-25 21:33  zhao_ry514114  阅读(9)  评论(0)    收藏  举报