Pagini recente » Diferente pentru problema/canguri intre reviziile 6 si 4 | Diferente pentru problema/urat intre reviziile 16 si 3 | Diferente pentru voronoi intre reviziile 38 si 37 | Monitorul de evaluare | Cod sursa (job #2627365)
#include <fstream>
using namespace std;
int dp[19][250010];
int main()
{
ifstream fin("stramosi.in");
ofstream fout("stramosi.out");
int n,m,i,j,q,p,contor;
fin>>n>>m;
for (i=1;i<=n;++i){
fin>>dp[i][0];
}
for (i=1;i<=18;++i){
for (j=1;j<=n;++j){
dp[j][i]=dp[dp[j][i-1]][i-1];
}
}
for(j=1;j<=m;++j){
fin>>q>>p;
contor=0;
while(p){
if (p&1==1){
q=dp[q][contor];
}
++contor;
p>>=1;
}
fout<<q<<'\n';
}
}