#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