Pagini recente » Cod sursa (job #1538546) | Cod sursa (job #919996) | Cod sursa (job #1818223) | runda/suceavaftw | Cod sursa (job #1101314)
#include <fstream>
#include <cmath>
using namespace std;
ifstream f("stramosi.in");
ofstream g("stramosi.out");
int N, Q, s[20][250005], lg, x, y;
int main()
{
f>>N>>Q;
lg=log2(N);
for (int i=1; i<=N; ++i)
f>>s[0][i];
for (int j=1; j<=lg; ++j)
for (int i=1; i<=N; ++i)
s[j][i]=s[j-1][s[j-1][i]];
for (int i=1; i<=Q; ++i)
{
f>>x>>y; y<<=1;
for (int k=0; k<=lg && x; ++k)
{
y>>=1;
if (y&1) x=s[k][x];
}
g<<x<<'\n';
}
return 0;
}