Pagini recente » Cod sursa (job #196071) | Cod sursa (job #1266361) | Cod sursa (job #964118) | Cod sursa (job #2888108) | Cod sursa (job #2916695)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("stramosi.in");
ofstream g("stramosi.out");
int n,m,i,j,a[19][250001],s,q,p,put,exp;
int main()
{
f>>n>>m;
for(i=1;i<=n;i++)
{
f>>a[1][i];
}
for(i=2;i<=18;i++)
{
for(j=1;j<=n;j++)
{
s=a[i-1][j];
a[i][j]=a[i-1][s];
}
}
for(i=1;i<=m;i++)
{
f>>q>>p;
put=1; exp=0;
while(put*2<=p)
{
put=put*2;
exp++;
}
if(put==p)
{
g<<a[exp+1][q]<<endl;
}
else
{
q=a[exp+1][q];
while(put<p)
{
put++;
q=a[1][q];
}
g<<q<<endl;
}
}
return 0;
}