Pagini recente » Cod sursa (job #429738) | Cod sursa (job #640749) | Cod sursa (job #88912) | Cod sursa (job #1574361) | Cod sursa (job #3234414)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("stramosi.in");
ofstream fout("stramosi.out");
int v[250250][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;
}