Pagini recente » Cod sursa (job #1633656) | Cod sursa (job #1715548) | Cod sursa (job #1164540) | Cod sursa (job #1424239) | Cod sursa (job #3261443)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("stramosi.in");
ofstream out("stramosi.out");
const int NMAX = 250000 + 1;
const int LOGMAX = 18 + 1;
int n, nr_query;
int stramos[LOGMAX][NMAX];
int log[NMAX];
void precalc()
{
for(int i=2; i<=n; i++)
{
log[i] = log[i/2] + 1;
}
for(int i=1; i<=18; i++)
{
for(int j=1; j<=n; j++)
{
stramos[i][j] = stramos[i-1][ stramos[i-1][j] ];
}
}
}
int main()
{
in>>n>>nr_query;
for(int i=1; i<=n; i++)
{
in>>stramos[0][i];
}
precalc();
for(int q=1; q<=nr_query; q++)
{
int a, b;
in>>a>>b;
while(b)
{
a = stramos[log[b]][a];
b -= 1<<log[b];
}
out<<a<<"\n";
}
return 0;
}