Pagini recente » Cod sursa (job #2544357) | Cod sursa (job #249877) | Cod sursa (job #2825458) | Cod sursa (job #2633193) | Cod sursa (job #3234413)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("stramosi.in");
ofstream fout("stramosi.out");
int v[250001][25], N, M;
int main()
{
fin >> N >> M;
for (int i = 1; i <= N; i++)
fin >> v[i][0];
for (int i = 1; i <= N; i++)
{
for (int j = 1; (1 << j) <= N; j++)
v[i][j] = v[v[i][j - 1]][j - 1];
}
while (M)
{
int x, y;
fin >> x >> y;
int rez = y;
for (int i = 0; (1 << i) <= y; i++)
{
if ((x & (1 << i)) != 0)
rez = v[rez][i];
}
fout << rez << "\n";
M--;
}
return 0;
}