Pagini recente » Cod sursa (job #2357146) | Cod sursa (job #1466637) | Cod sursa (job #966368) | Cod sursa (job #963156) | Cod sursa (job #2902816)
#include<iostream>
#include <fstream>
using namespace std;
ifstream in("stramosi.in");
ofstream out("stramosi.out");
int mat[21][250003];
int main()
{
int n, q, i, j, poz, k, sol;
in>>n>>q;
cout<<1;
for(i = 1; i <= n; i++)
in>>mat[0][i];
cout<<1;
for(i = 1; i <= 18; i++)
for (j = 1; j <= n; j++)
mat[i][j] = mat[i-1][mat[i-1][j]];
cout<<1;
for(i = 1; i <= q; i++)
{
in>>poz>>k;
sol = 0;
while(k > 0)
{
if(k%2 == 1) poz = mat[sol][poz];
sol++;
k /= 2;
}
out<<poz<<"\n";
}
return 0;
}