C/C++中rand函数的实现

C/C++中用了最简单的线性同余来实现伪随机数的,具体原理看这里

具体的参数a,c,m参考这里


#include<bits/stdc++.h>
using namespace std;

unsigned int status=0;
int my_srand(unsigned int seed){
    status=seed;
}
int my_rand(){
    status=214013*status+2531011;
    return status>>16&((1<<15)-1);
}

int main()
{
    int seed=12365;
    srand(seed);
    for(int i=0;i<10;i++) cout<<rand()<<" ";cout<<endl;
    my_srand(seed);
    for(int i=0;i<10;i++) cout<<my_rand()<<" ";cout<<endl;
    return 0;
}

在我的编译器中,a=214013, c=2531011, m=2^32, 最后结果取了二进制的第31位到第17位,这15位的二级制,所以rand产生的数最大就是32767(2^15-1)了.

当然还有其他算法,参考这里


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值