Cod sursa(job #2321621)
| Utilizator | Data | 16 ianuarie 2019 13:19:42 | |
|---|---|---|---|
| Problema | Stramosi | Scor | 100 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva de probleme | Marime | 0.52 kb |
#include <fstream>
int mat[25][250001], i, j, k;
int main() {
std::ifstream is{"stramosi.in"};
int n, m;
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';
}
}
