Cod sursa(job #1486485)

Utilizator FairPlay94George Cioroiu FairPlay94 Data 14 septembrie 2015 22:16:19
Problema Stramosi Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.94 kb
#include <cstdio>
#include <iostream>
#include <vector>

using namespace std;

int main() {
    freopen("stramosi.in", "r", stdin);
    freopen("stramosi.out", "w", stdout);

    ios::sync_with_stdio(false);
    cin.tie(0);

    vector<int> str[250005];
    int n, m;
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        str[i][0] = 0;
    }
    for (int i = 1; i <= n; i++) {
        cin >> str[i][1];
    }
    for (int i = 0; i <= 20; i++) {
        str[0][i] = 0;
    }
    for (int i = 1; i <= n; i++) {
        for (int j = 2; j <= 20; j++) {
            str[i][j] = str[str[i][j - 1]][j - 1];
        }
    }
    for (int i = 1; i <= m; i++) {
        int q, p, r = 1;
        cin >> q >> p;
        while (q !=0 && p > 0) {
            if (p % 2 == 1) {
                q = str[q][r];
            }
            p >>= 1;
            r++;
        }
        cout << q << "\n";
    }


    return 0;
}