Pagini recente » Cod sursa (job #2615199) | Cod sursa (job #2026811) | Cod sursa (job #362859) | Cod sursa (job #1737413) | Cod sursa (job #911379)
Cod sursa(job #911379)
// dp[i][j] = al 2^i-lea stramos al lui j
// dp[i][j] = dp[i-1][dp[i-1][j]]
#include<cstdio>
using namespace std;
const int NMAX = 250005;
const int logN = 20;
int n,m,i,j,k,dp[logN][NMAX],p,q;
int main()
{
freopen("stramosi.in","r",stdin);
freopen("stramosi.out","w",stdout);
scanf("%d%d",&n,&m);
for(i=1;i<=n;i++) scanf("%d",&dp[0][i]);
for(i=1,k=2;k<=n;i++,k<<=1)
for(j=1;j<=n;j++) dp[i][j]=dp[i-1][dp[i-1][j]];
for(;m;m--)
{
scanf("%d%d",&q,&p);
while(p && q)
{
for(i=0,k=1;k<=p;i++,k<<=1); k>>=1; i--;
q=dp[i][q];
p-=k;
}
printf("%d\n",q);
}
return 0;
}