Pagini recente » Cod sursa (job #1736717) | Cod sursa (job #285331) | Cod sursa (job #4938) | Cod sursa (job #1517568) | Cod sursa (job #2183318)
#include <bits/stdc++.h>
using namespace std;
ifstream F("lca.in");
ofstream G("lca.out");
int n, m, d[20][100005], x, y, maxx;
int main()
{
F >> n >> m;
for(int i = 2; i <= n; ++ i){
F >> d[0][i];
}
for(int i = 1; i <= 17; ++ i)
for(int j = 1; j <= n; ++ j)
d[i][j]=d[i-1][d[i-1][j]];
while(m--){
F >> x >> y;
maxx=-1;
for(int i = 0; i <= 17; ++ i)
for(int j = 0; j <= 17; ++ j)
if(d[i][x] == d[j][y]) maxx=max(maxx, d[i][x]);
if(d[0][x]==y) maxx=max(maxx, d[0][x]);
if(d[0][y]==x) maxx=max(maxx, d[0][y]);
if(y==x) maxx=max(maxx, x);
G<<maxx<<'\n';
}
return 0;
}