题目:
代码:
1. 小数据 时间复杂度O( nm )
#include<bits/stdc++.h>
using namespace std;
vector<int>edge[1005];
int father[1005],dist[1005],n,m;
void dfs(int x){
for(auto y:edge[x]){
dist[y]=dist[x]+1;
dfs(y);
}
}
int main(){
scanf("%d",&n);
for(int i=1;i<n;i++){
int x,y;
scanf("%d%d",&x,&y);
edge[x].push_back(y);
father[y]=x;
}
memset(dist, 0,sizeof(dist));
dfs(1);
scanf("%d",&m);
for(int i=1;i<=m;i++){
int x,y;
scanf("%d%d",&x,&y);
if(dist[x]<dist[y])swap(x,y);
int z=dist[x]-dist[y];
//谁的深度大谁往上跳,直到同一深度
for(int j=1;j<=z;j++)x=father[x];
while(x!=y)x=father[x],y=father[y];
printf("%d\n",x);
}
return 0;
}
2. 大数据量
用了一个什么倍增思想没听懂。。。。