zoukankan      html  css  js  c++  java
  • 生命游戏和随机数之间某种不可言说的秘密

    为什么我感觉随便写一个一维生命游戏规则就可以做出一个看起来很随机实际上也蛮随机的随机数生成器....

    这是代码:

     1 #include <cstdio>
     2 #include <fstream>
     3 #include <iostream>
     4  
     5 #include <cstdlib>
     6 #include <cstring>
     7 #include <algorithm>
     8 #include <cmath>
     9  
    10 #include <queue>
    11 #include <vector>
    12 #include <map>
    13 #include <set>
    14 #include <stack>
    15 #include <list>
    16  
    17 typedef unsigned int uint;
    18 typedef long long int ll;
    19 typedef unsigned long long int ull;
    20 typedef double db;
    21  
    22 using namespace std;
    23  
    24 inline int getint()
    25 {
    26     int res=0;
    27     char c=getchar();
    28     bool mi=false;
    29     while(c<'0' || c>'9') mi=(c=='-'),c=getchar();
    30     while('0'<=c && c<='9') res=res*10+c-'0',c=getchar();
    31     return mi ? -res : res;
    32 }
    33 inline ll getll()
    34 {
    35     ll res=0;
    36     char c=getchar();
    37     bool mi=false;
    38     while(c<'0' || c>'9') mi=(c=='-'),c=getchar();
    39     while('0'<=c && c<='9') res=res*10+c-'0',c=getchar();
    40     return mi ? -res : res;
    41 }
    42  
    43 db eps=1e-80;
    44 inline bool feq(db a,db b)
    45 { return fabs(a-b)<eps; }
    46 
    47 template<typename Type>
    48 inline Type avg(const Type a,const Type b)
    49 { return a+((b-a)/2); }
    50 
    51 //==============================================================================
    52 //==============================================================================
    53 //==============================================================================
    54 //==============================================================================
    55 
    56 int n,m;
    57 
    58 int a[2][1005000];
    59 
    60 bool rd[1005000];
    61 int rt=0;
    62 int lastrand=7;
    63 int getrand() 
    64 {
    65     int res=0;
    66     for(int i=0;i<10;i++) res+=(rd[lastrand+(i<<1)]<<i);
    67     lastrand++;
    68     return res;
    69 }
    70 
    71 
    72 
    73 int main()
    74 {
    75     freopen("in.txt","r",stdin);
    76     freopen("out.txt","w",stdout);
    77     
    78     n=getint();
    79     
    80     int mid=n*2,s=0;
    81     a[0][mid]=1;
    82     for(int i=1;i<n;i++)
    83     {
    84         for(int j=mid-i;j<=mid+i;j++)
    85         a[!s][j]=a[s][j]+a[s][j-2]^a[s][j+1]-a[s][j]^a[s][j+1]+a[s][j+1];
    86         s^=1;
    87         
    88         for(int j=mid-i;j<=mid+i;j++) rd[rt++]=(a[s][j]<0);
    89     }
    90     
    91     for(int i=0;i<12500;i++) cout<<getrand()<<',';
    92     
    93     
    94     return 0;
    95 }
    View Code

    种子可以设lastrand,也可以设lastrand的增量,甚至是要取哪些数据计算随机数...

    下面是按照以上代码生成0到1023的随机数12500个.

    看起来左边有点多?....不过应该也足够....随机了.....

    接下来的任务是给它写一个能用的class.....

    allocate之类的最讨厌了囧...

    然后下边是有趣的东西.....

    这是在cout<<getrand()后加了%611的结果.这告诉我们千万不要对原生随机数乱取模!......

    但是我就想要0到611之间的随机数呢?

    呃....把原区间用double对应到[0,1]范围内再乘回去似乎是个可行的办法....

    看起来常数有点大,我做梦的时候想想有没有更好的......

  • 相关阅读:
    Keep it simple & stupid
    BZOJ 2631: tree( LCT )
    BZOJ 2843: 极地旅行社( LCT )
    BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊( LCT )
    BZOJ 1742: [Usaco2005 nov]Grazing on the Run 边跑边吃草( dp )
    BZOJ 3531: [Sdoi2014]旅行( 树链剖分 )
    BZOJ 1269: [AHOI2006]文本编辑器editor( splay )
    BZOJ 2016: [Usaco2010]Chocolate Eating( 二分答案 )
    BZOJ 1734: [Usaco2005 feb]Aggressive cows 愤怒的牛( 二分答案 )
    BZOJ 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱( dp )
  • 原文地址:https://www.cnblogs.com/DragoonKiller/p/4321070.html
Copyright © 2011-2022 走看看