Advertisement
Guest User

Untitled

a guest
Oct 28th, 2016
57
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.91 KB | None | 0 0
  1. #include <iostream>
  2. #include<fstream>
  3. using namespace std;
  4. ifstream f("stramosi.in");
  5. ofstream g("stramosi.out");
  6. int n,q,i,v[250001],log2[20],p,k,r[250001][20],p2,j;
  7. inline void BuildRMQ()
  8. {
  9.     int m=log2[n]+1,i,j;
  10.     for(i=1; i<=n; i++)
  11.         r[i][0]=v[i];
  12.     for(j=1; j<m; j++)
  13.         for(i=1; i<=n; i++)
  14.             r[i][j]=r[r[i][j-1]][j-1];
  15. }
  16. inline int functie(int p,int k)
  17. {
  18.     while(k && p)
  19.     {
  20.         bool ok=1;
  21.         for(int i=log2[k]+1; i>=0 && ok; i--)
  22.             if(k&(1<<i))
  23.             {
  24.                 ok=0;
  25.                 p=r[p][log2[k]];
  26.                 k-=(1<<i);
  27.             }
  28.     }
  29.     return p;
  30. }
  31. int main()
  32. {
  33.     f>>n>>q;
  34.     for(i=1; i<=n; i++)
  35.         f>>v[i];
  36.     log2[1]=0;
  37.     for(i=2; i<=n; i++)
  38.         log2[i]=log2[i/2]+1;
  39.     BuildRMQ();
  40.     for(; q; q--)
  41.     {
  42.         f>>p>>k;//al k lea stramos al lui p
  43.         g<<functie(p,k)<<'\n';
  44.     }
  45. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement