热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c/c++开发分享rand()在OSX上是否会返回零?

我已经运行这个代码差不多十个小时没有爱情:while(true){intrrand();assert(r!0);}我希望rand()最终滚零,从而触发断言。我做错了什么或rand(

我已经运行这个代码差不多十个小时没有爱情:

while ( true ) { int r = rand(); assert( r != 0 ); } 

我希望rand()最终滚零,从而触发断言。

我做错了什么或rand()永远不会返回零?

或者我没有等待足够长的时间来期待看到它? 我是2012年复古的2GHz i7。

    如果此链接是Mac OS X rand()的定义,则永远不会生成0。 它不是一个非常好的伪随机数发生器,恕我直言。

    在其他缺陷中,其状态是先前返回的值,这意味着它是从先前值到下一个值的严格函数; 它的周期不能大于它的范围,即[1, RAND_MAX-1] 。 (它不能产生0,因为0是算法中的一个定点。)

    该标准要求对rand连续调用形成一个序列,该序列是空间的子集[0; RAND_MAX] [0; RAND_MAX] 。 它不要求所有可能的值都出现在任何可能的序列中。

    所以回答你的问题:你不能保证得到零; 这取决于实现(从其他答案来看,BSD libc的实现确实永远不会返回0 )。

    §7.22.2.2

    不能保证产生的随机序列的质量,并且已知一些实现产生具有令人沮丧的非随机低阶位的序列。

    编辑:@rici说的话。

    看起来FreeBSD rand永远不会返回0

    该消息链有一个补丁,但它不包含在apple开源源中。

    它应该最终返回零,但在我的计算机上, RAND_MAX是2147483647

    printf("rand_max = %drn", RAND_MAX);

    Wolfram alpha无法计算出这么小的概率。

    运行这些示例:

    prob x>0 for x binomial with n=100000 and p=.00001

    prob x>0 for x binomial with n=10000 and p=.0001

    prob x>0 for x binomial with n=1000 and p=.001

    表明在1 / N的概率之后,N次尝试似乎接近约0.63

    它确实看起来像5 * N尝试应该让你超过99%。

    我不知道你的计算机需要多长时间才能拨打100亿个rand电话。

      以上就是c/c++开发分享rand()在OSX上是否会返回零?相关内容,想了解更多C/C++开发(异常处理)及C/C++游戏开发关注(编程笔记)。


      推荐阅读
      • 提升Python编程效率的十点建议
        本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
      • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
      • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
      • CSS3选择器的使用方法详解,提高Web开发效率和精准度
        本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
      • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
      • [译]技术公司十年经验的职场生涯回顾
        本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
      • 向QTextEdit拖放文件的方法及实现步骤
        本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
      • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
      • Linux重启网络命令实例及关机和重启示例教程
        本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
      • 开发笔记:加密&json&StringIO模块&BytesIO模块
        篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
      • IB 物理真题解析:比潜热、理想气体的应用
        本文是对2017年IB物理试卷paper 2中一道涉及比潜热、理想气体和功率的大题进行解析。题目涉及液氧蒸发成氧气的过程,讲解了液氧和氧气分子的结构以及蒸发后分子之间的作用力变化。同时,文章也给出了解题技巧,建议根据得分点的数量来合理分配答题时间。最后,文章提供了答案解析,标注了每个得分点的位置。 ... [详细]
      • 给定一个二维平面上的一些点,通过计算曼哈顿距离,求连接所有点的最小总费用。只有任意两点之间有且仅有一条简单路径时,才认为所有点都已连接。给出了几个示例并给出了对应的输出。 ... [详细]
      • 本文介绍了基于c语言的mcs51单片机定时器计数器的应用教程,包括定时器的设置和计数方法,以及中断函数的使用。同时介绍了定时器应用的举例,包括定时器中断函数的编写和频率值的计算方法。主函数中设置了T0模式和T1计数的初值,并开启了T0和T1的中断,最后启动了CPU中断。 ... [详细]
      • 本文介绍了游戏开发中的人工智能技术,包括定性行为和非定性行为的分类。定性行为是指特定且可预测的行为,而非定性行为则具有一定程度的不确定性。其中,追逐算法是定性行为的具体实例。 ... [详细]
      • 如何用UE4制作2D游戏文档——计算篇
        篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
      author-avatar
      和尚与尼姑离婚
      这个家伙很懒,什么也没留下!
      PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
      Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有