Pagini recente » Cod sursa (job #463771) | Cod sursa (job #961396) | Cod sursa (job #1153666) | Cod sursa (job #2639078) | Cod sursa (job #2679753)
#include <fstream>
#include <vector>
using namespace std;
int v[250005][18],vp[20];
int main()
{
ifstream cin("stramosi.in");
ofstream cout("stramosi.out");
int n,m,x,y,i,k,r,kk;
cin >> n >> m;
for(int i=1;i<=n;i++)
{
cin >> x;
if(x>0)
v[i][0]=x;
}
for(int j=1;j<=17;j++)
{
for(int i=1;i<=n;i++)
{
v[i][j]=v[v[i][j-1]][j-1];
}
}
for(int i=0;i<18;i++)
vp[i]=(1 << i);
for(int j=1;j<=m;j++)
{
cin >> x >> y;
i=0;
while(v[x][i+1]>0 && vp[i+1]<=y)
i++;
k=vp[i];
r=v[x][i];
for(int i=k+1;i<=y;i++)
r=v[r][0];
cout << r << '\n';
}
return 0;
}