专栏首页ACM小冰成长之路通过若干次 rand() 使得随机数的和超过 RAND_MAX 的随机次数的期望

通过若干次 rand() 使得随机数的和超过 RAND_MAX 的随机次数的期望

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

const int MAXN = 1e8;

int main() {
    printf("rand: 0-%d:\n", RAND_MAX);
    
    long long cnt1 = 0;
    for (int i = 0; i < MAXN; i++)
        for (long long j = 0; j < RAND_MAX; j += rand())
            cnt1++;
    
    printf("%f\n", cnt1 * 1.0 / MAXN);
    
    long long cnt2;
    for (int k = 0; k < 10; k++)
    {
        cnt2 = 0;
        srand((unsigned)time(NULL));
        for (int i = 0; i < MAXN; i++)
            for (long long j = 0; j < RAND_MAX; j += rand())
                cnt2++;
        
        printf("%d: %f\n", k, cnt2 * 1.0 / MAXN);
    }
    
    return 0;
}

这里不管通过什么样的随机种子(seedseedseed),最后得到的期望都是接近于 2.71828…2.71828…2.71828… 的,也就是接近于自然常数 eee,充分的体现了 rand()rand()rand() 的稳定性。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • C++ rand 与 srand 的用法

    计算机的随机数都是由伪随机数,即是由小M多项式序列生成的,其中产生每个小序列都有一个初始值,即随机种子。(注意:小M多项式序列的周期是65535,即每次利用一个...

    编程范 源代码公司
  • 【C++简明教程】随机数生成

    【C++ 简明教程】每次更新将会以代码块的形式发布,可以作为手册或者模块以供查询。

    机器视觉CV
  • 【干货】小白如何熟练掌握C语言随机数!

    随机数的使用,是不少小伙伴在学C语言过程中都会遇到的一个坎,今天老九为大家讲解如何在C语言中使用随机数。 通常情况下,使用最多的方法的就是使用rand函数随机生...

    老九君
  • 序列比对(16)Baum-Welch算法估算HMM参数

    前文《序列比对(15)EM算法以及Baum-Welch算法的推导》介绍了EM算法和Baum-Welch算法的推导过程。Baum-Welch算法是EM算法的一个特...

    一只羊
  • 生成随机数的方式你选对了吗?

    首先需要说明的是,计算机中生成的随机数严格来说都是伪随机,即非真正的随机数,真正随机数的随机样本不可重现。那么我们来看看代码中有哪些方式可以生成随机数。

    编程珠玑
  • 生成随机数的方式你选对了吗?

    首先需要说明的是,计算机中生成的随机数严格来说都是伪随机,即非真正的随机数,真正随机数的随机样本不可重现。那么我们来看看代码中有哪些方式可以生成随机数。

    帅地
  • 【编程基础】C语言产生随机数需要了解的几个函数

    C语言产生随机数是一个常见的编程功能任务,当然这个也不难,调用两三个函数就出来了,但是你知道这些函数具体是起到怎样的作用,并且是它们是如何产生随机数的吗? 几...

    程序员互动联盟
  • C语言中随机数相关问题

    用C语言产生随机数重要用到rand函数、srand函数、及宏RAND_MAX(32767),它们均在stdlib.h中进行了声明。 int rand(void)...

    用户1221057
  • PHP内置函数生成随机数实例

    rand() 函数可以不加任何参数,就可以生成随机整数。如果要设置随机数范围,可以在函数中设置 min 和 max 的值。如果需要生成随机数的种子,使用 sra...

    砸漏

扫码关注云+社区

领取腾讯云代金券