1

我现在正在学习treap,我遇到了一个实现,其中那个家伙使用了一些奇怪的方式来生成优先级的随机数。我无法得到它。有人介意解释一下它是如何工作的。

     struct xor_128
     {
         ull x,y,z,w;
         xor_128(): x(1234567892851659llu), y(3631515817918578190llu),z(711737163082llu), w(916951651388197517llu) {}
         ull next()
       {
          ull t=x^(x<<11);// ull is unsigned long long he used
          x=y;
          y=z;
          z=w;
          return w=w^(w>>19)^t^(t>>8);
       }
    };
4

0 回答 0