Pagini recente » Cod sursa (job #199394) | Cod sursa (job #767506) | Cod sursa (job #2621201) | Cod sursa (job #3165785) | Cod sursa (job #2812988)
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("stramosi.in");
ofstream fout ("stramosi.out");
const int DIM = 250050;
int lvl[DIM], dp[DIM][19];
int n, q, nod, up;
int main (){
fin >> n >> q;
for(int i = 1; i <= n; i++)
fin >> dp[i][0];
for(int j = 1; (1 << j) <= n; j++)
for(int i=1; i<=n; i++)
dp[i][j] = dp[ dp[i][j-1] ][j-1];
int p2;
while(q--){
fin >> nod >> up;
p2 = 0;
while(up != 0){
if(up&1)
nod = dp[nod][p2];
p2++;
up >>= 1;
}
fout << nod << "\n";
}
return 0;
}