Cod sursa(job #2450297)

Utilizator bluestorm57Vasile T bluestorm57 Data 22 august 2019 16:19:28
Problema Stramosi Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.7 kb
#include <bits/stdc++.h>

using namespace std;

ifstream f("stramosi.in");
ofstream g("stramosi.out");

const int NMAX = 250005;
const int LMAX = 30;
int dp[LMAX][NMAX],lg[NMAX];
int n,q;

int main(){
    int i,x,y,j;
    f >> n >> q;
    for(i = 1 ; i <= n ; i++)
        f >> dp[0][i];
    for(i = 2 ; i <= n ; i++)
        lg[i] = lg[i / 2] + 1;

    j = 1;
    while((1 << j) <= n){
        for(i = 1 ; i <= n ; i++)
            dp[j][i] = dp[j - 1][dp[j - 1][i]];
        j++;
    }

    while(q--){
        f >> x >> y;
        while(y && x != 0){
            x = dp[lg[y]][x];
            y = y - (1 << lg[y]);
        }
        g << x << "\n";
    }

    return 0;
}