Pagini recente » Cod sursa (job #2075478) | Cod sursa (job #1632506) | Cod sursa (job #1400951) | Cod sursa (job #364171) | Cod sursa (job #1253272)
#include <iostream>
#include <cstdio>
using namespace std;
#define maxN 250005
#define maxLog 25
#define maxLLog 20
long n,m,i,j,q,p,tmp;
long dp[maxN][maxLog];
bool util;
char s[250000*6+5];
void read(){
gets(s);
long pos = 0;
for(long i=1;i<=n;i++){
while(s[pos] >= '0' && s[pos] <= '9')
dp[i][0] = dp[i][0]*10 + s[pos++] - '0';
while(s[pos] < '0' || s[pos] > '9') pos++;
}
}
int main()
{
freopen("stramosi.in","r",stdin);
freopen("stramosi.out","w",stdout);
scanf("%ld %ld\n",&n,&m);
read();
//for(i=1;i<=n;i++) scanf("%ld",&dp[i][0]);
for(j=1;j<=maxLLog;j++){
util = false;
for(i=1;i<=n;i++){
if(!dp[dp[i][j-1]][j-1]) continue;
dp[i][j] = dp[dp[i][j-1]][j-1];
util = true;
}
if(!util) break;
}
for(;m;m--){
scanf("%ld %ld",&q,&p);
i = 0; tmp = 1;
while(tmp << 1 <= p) tmp <<= 1,i++;
while(i>=0){
if(p&tmp) q = dp[q][i];
tmp >>= 1;
i--;
if(!q) break;
}
printf("%ld\n",q);
}
return 0;
}