Pagini recente » Cod sursa (job #968747) | Cod sursa (job #2875277) | Cod sursa (job #950002) | Cod sursa (job #3203524) | Cod sursa (job #1373866)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("stramosi.in");
ofstream g("stramosi.out");
int n,m,x,y,dp[20][250005];
int main()
{
f>>n>>m;
for(int i=1; i<=n; i++)
f>>dp[0][i];
for(int i=1; (1<<i)<=n; i++)
for(int j=1; j<=n; j++)
dp[i][j]=dp[i-1][dp[i-1][j]];
for(int i=1; i<=m; i++)
{
f>>x>>y;
for(int i=0; (1<<i)<=y; i++)
{
if(y&(1<<i))x=dp[i][x];
if(x==0)break;
}
g<<x<<"\n";
}
return 0;
}