P3379 100pts但UNAC求调
查看原帖
P3379 100pts但UNAC求调
914941
eszrdxtfc楼主2024/12/21 13:37
#include<bits/stdc++.h>
using namespace std; 
inline int read()
{
	int x=0,f=1;char ch=getchar();
	while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}
	while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}
	return x*f;
}
int n,m,s;
const int N=5000051;
vector<int> e[N];
int dep[N];
int f[N][30];
void dfs(int x,int fa){
	dep[x]=dep[fa]+1;
	f[x][0]=fa;
	for(auto y:e[x]){
		if(y==fa) continue;
		dfs(y,x);
	}
	
}

void st(){
	int maxp=log2(n+1)+1;
	for(int p=1;p<maxp;p++){
		for(int i=1;i<=n;i++){
			f[i][p]=f[f[i][p-1]][p-1];
			//cout<<f[i][p]<<" ";
		}
		//cout<<endl;
	}
}
int lca(int x,int y){
	int maxp=log2(n+1); 
	if(dep[x]>dep[y]) swap(x,y);
	for(int p=maxp-1;p>=0;p--){
		if(dep[f[y][p]]>=dep[x]){
			y=f[y][p];
		}
	}
	if(x==y){
		return x;
	}
	for(int p=maxp-1;p>=0;p--){
		if(f[x][p]!=f[y][p]){
			x=f[x][p];
			y=f[y][p];
		}
	}
	return f[x][0];
}
signed main(){
	n=read();
	m=read();
	s=read();
	for(int i=1;i<n;i++){
		int x=read();
		int y=read();
		e[x].push_back(y);
		e[y].push_back(x);
	}
	dfs(s,0);
	st();
	for(int i=1;i<=m;i++){
		int x=read();
		int y=read();
		printf("%d\n",lca(x,y));
		
	}
	return 0;
	
}

13 14样例过不了 求调!!

qwq

2024/12/21 13:37
加载中...