Pagini recente » Cod sursa (job #367625) | Cod sursa (job #3198568) | Cod sursa (job #2174303) | Cod sursa (job #481649) | Cod sursa (job #1708074)
#include <iostream>
#include <fstream>
#include <cmath>
using namespace std;
int rmq[250100][20];
int v[25];
int n, m, i, j;
ifstream f("stramosi.in");
ofstream g("stramosi.out");
int main()
{
for(i=0; i<25; ++i)
v[i]=(1<<i);
f>>n>>m;
for(i=1; i<=n; ++i)
{
f>>rmq[i][0];
}
int k=log2(n);
for(i=1; i<=k; ++i)
{
for(j=1; j<=n; ++j)
rmq[j][i]=rmq[rmq[j][i-1]][i-1];
}
int p,q;
for(i=1; i<=m; ++i)
{
f>>p>>q;
while(q && p)
{
k=log2(q);
p=rmq[p][k];
q-=v[k];
}
g<<p<<'\n';
}
}