Pagini recente » Cod sursa (job #2683980) | Cod sursa (job #1481956) | Cod sursa (job #1389613) | Cod sursa (job #895893) | Cod sursa (job #3142746)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("stramosi.in");
ofstream fout("stramosi.out");
int n, q, i, j, x, y;
int main() {
fin >> n >> q;
vector<vector<int>> s(n + 2, vector<int>(20));
for(i = 1; i <= n; i++) fin >> s[i][0];
for(j = 1; j < 19; j++) {
for(i = 1; i <= n; i++) s[i][j] = s[s[i][j - 1]][j - 1];
}
while(q--) {
fin >> x >> y;
for(i = 18; i >= 0; i--) {
if(y >= (1 << i)) {
x = s[x][i];
y -= (1 << i);
}
}
fout << x << "\n";
}
return 0;
}