Cod sursa(job #442451)
Utilizator | Data | 14 aprilie 2010 16:25:10 | |
---|---|---|---|
Problema | Stramosi | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.39 kb |
#include <fstream>
using namespace std;
int v[20][1<<18];
int main()
{
int n,m,p,q,i,j;
ifstream in("stramosi.in");
ofstream out("stramosi.out");
in>>n>>m;
for (i=1;i<=n;i++)
in>>v[0][i];
for (i=1;i<=18;i++)
for (j=1;j<=n;j++)
v[i][j]=v[i-1][v[i-1][j]];
while (m--)
{
in>>q>>p;
for (i=0;p && q;++i,q/=2)
if (q%2)
{
p=v[i][p];
}
out<<p<<"\n";
}
return 0;
}