Pagini recente » Cod sursa (job #1314872) | Cod sursa (job #952437) | Cod sursa (job #1578796) | Cod sursa (job #2376964) | Cod sursa (job #947051)
Cod sursa(job #947051)
#include<stdio.h>
using namespace std;
int v[20][250001];
int n,m,p,q,i,j;
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",&v[0][i]);
for(i=1;i<=17;i++)
for(j=1;j<=n;j++)
v[i][j]=v[i-1][v[i-1][j]];
while(m!=0){
m--;
scanf("%d%d",&q,&p);
i=0;
for(i=0;p;++i)
while(i<=p){
if(p&(1<<i)){
q=v[i][q];
p-=(1<<i);
}
i++;
}
printf("%d\n",q);
}
return 0;
}