Pagini recente » Cod sursa (job #2120961) | Cod sursa (job #1671787) | Cod sursa (job #1709260) | Cod sursa (job #2480250) | Cod sursa (job #3123736)
#include <bits/stdc++.h>
using namespace std;
int main() {
ifstream cin("stramosi.in");
ofstream cout("stramosi.out");
int n, m; cin >> n >> m;
vector<int> par(n + 1);
for (int i = 1; i <= n; ++i)
cin >> par[i];
vector<int> qv(m), qk(m);
for (int i = 0; i < m; ++i)
cin >> qv[i] >> qk[i];
vector<int> npar(n + 1);
for (int d = 0; d < 20; ++d) {
for (int i = 0; i < m; ++i)
if (qk[i] & (1 << d))
qv[i] = par[qv[i]];
for (int i = 1; i <= n; ++i)
npar[i] = par[par[i]];
swap(par, npar);
}
for (int i = 0; i < m; ++i)
cout << qv[i] << "\n";
return 0;
}