zoukankan      html  css  js  c++  java
  • 线性同余法的伪随机数

    学校练习,简单的我就不放上来了,值得整理的,我保存一下

    习题9

    1.1. 伪随机数(线性同余法)

     

    1.1.1.算法描述

     

    我们使用线性同余法,来限定一些离散点在y=a*x+b上。

     

    1.1.2.伪代码

     

    random(n,m,seed,a,b)

    //根据现行同余法生成n个伪随机书的一个序列

    //输入:一个正整数n和正整数参数m,seed,a,b

    //输出:随机数组

    r0<-seed

    for i<-1 to n do

      ri<-(a*ri-1+b) mod m

    end

     

    1.1.3.算法实现

     

    public static long[] random(int n,int m,long seed,int a,int b){
        long[] val=new long[n];
        val[0]=seed%m;
        for(int i=1;i<n;i++) val[i]=(a*val[i-1]+b)%m;
        return val;
    }

     

    1.2. 算法小结

     

    使用线性同于法,复杂度a[n],能实现比较类随机的伪随机。

  • 相关阅读:
    test example
    SSD: ReLU6
    jupyter
    ubuntu+anaconda
    linux动态库
    ssd制作数据和训练
    ncnn框架
    Lock->ReentrantLock->ReentrantReadWriteLock简介
    Synchronized简介与原理
    ThreadLocal简介与原理
  • 原文地址:https://www.cnblogs.com/littlepage/p/11515534.html
Copyright © 2011-2022 走看看