Pagini recente » Cod sursa (job #2215164) | Cod sursa (job #1799467) | Cod sursa (job #2089145) | Cod sursa (job #2719087) | Cod sursa (job #2321622)
#include <fstream>
int mat[25][250001], n, m, i, j, k;
int main() {
std::ifstream is{"stramosi.in"};
is >> n >> m;
for (i = 1; i <= n; ++i)
is >> mat[0][i];
for (k = 1; (1 << k) <= n; ++k)
for (j = 1; j <= n; ++j)
mat[k][j] = mat[k - 1][mat[k - 1][j]];
std::ofstream os{"stramosi.out"};
while (m--) {
int q, p, exp{};
is >> q >> p;
while (p) {
if (p & 1)
q = mat[exp][q];
++exp;
p >>= 1;
}
os << q << '\n';
}
}