Cod sursa(job #1043144)

Utilizator PasparanPasparan Ana-Maria Pasparan Data 28 noiembrie 2013 01:12:07
Problema Stramosi Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.55 kb
#include<stdio.h>

int v[22][250010];

int main()
{
FILE *in=fopen("stramosi.in","r"),
     *out=fopen("stramosi.out","w");

int n,m,i,j,p,q;
fscanf(in,"%d%d",&n,&m);

for(i=1;i<=n;i++)
   fscanf(in,"%d",&v[0][i]);

for(i=1;i<=19;i++)
  for(j=1;j<=n;j++)
     v[i][j]=v[i-1][v[i-1][j]];

int nb;
for(i=1;i<=m;i++)
   {
   fscanf(in,"%d%d",&p,&q);

   while(q)
   {
   nb=0;
   while((1<<nb) <= q) nb++;
   nb--;

   q-=(1<<nb);
   p=v[nb][p];
   }

   fprintf(out,"%d\n",p);
   }

fclose(in);
fclose(out);
return 0;
}