Pagini recente » Cod sursa (job #2774804) | Cod sursa (job #2976019) | Cod sursa (job #2377219) | Cod sursa (job #2145225) | Cod sursa (job #3234420)
#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 > 0)
{
int p, q;
fin >> q >> p;
int rez = q;
for (int i = 0; (1 << i) <= p; i++)
{
if ((p & (1 << i)) != 0)
rez = v[rez][i];
}
fout << rez << "\n";
M--;
}
return 0;
}