线性同余法的伪随机数

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

习题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],能实现比较类随机的伪随机。

 

转载于:https://www.cnblogs.com/littlepage/p/11515534.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值