C语言中构造随机数原理及rand()取余构造随机数方法

2023-10-28

    在C语言中,ANSIC C程序库提供rand()函数来产生随机数。但事实上,rand()是并不是一个真正的随机数产生器,即可以预测随机序列的顺序,在默认随机种子情况下产生0~99之间的随机数,其随机序列为{83,86,77,15,……},比如以下程序:

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

int main(){
    int num;
    printf("A set of random numbers:\n");
    for(int i = 0; i < 10; i++){
        num = rand()%100; //产生0-99之间的随机数;
        printf("%d ",num);
    }
    putchar('\n');
    return 0;
}

    编译、执行结果:

    可以看出,在执行三次情况下,rand()产生的随机序列都是一样的。这是因为,rand()使用的是产生伪随机数的“魔术公式”,它的随机数种子是一直没有变的,所以每次产生的随机序列是一样的。在调用rand()函数之前,可以使用srand()函数设置随机数种子,如果没有设置随机数种子,rand()函数在调用时,自动设计随机数种子为1。随机种子相同,每次产生的随机数也会相同。rand()函数被包含在头文件<stdlib.h>中。

    如果想要构造每次产生不同的随机数序列的函数,则需要引入一个不断变化的随机种子。最常用的就是时间变量,利用时间函数time()获取系统时间(其返回值time_t一定是数值类型)。time()的参数是一个time_t类型对象的地址,时间值则存储在该地址中。所以,可以使用空指针0或者NULL作为参数。此时,时间通过返回值机制提供。time()函数包含在头文件<time.h>中。写一个简单地程序说明time()函数;

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

int main(){
    int num1,num2;
    printf("The return value of time:\n");
    num1 = time(0);
    num2 = time(NULL);
    printf("%d,%d\n",num1,num2);
    return 0;
}

    编译并执行三次:

    可以看出,使用空指针0或者NULL作为参数得到的结果是一致的,但是每次执行的结果不一样。将时间函数作为随机种子:

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

int main(){
    int num;
    srand(time(0)); //将时间函数传入到随机数产生函数;
    printf("A set of random numbers:\n");
    for(int i = 0; i < 10; i++){
        num = rand()%100;
        printf("%d ",num);
    }
    putchar('\n');
    return 0;
}

    执行结果:

    在将时间函数作为随机种子之后,可以发现每次产生的随机序列都不在一样。此时。需要考虑如何产生一定范围内的随机数。rand()产生的是从0到RAND_MAX(32767)之间的伪随机数(正整数),如果我们想要1~100之间的随机序列呢?这里我们用到了取余%运算,一个正整数对5取模运算,产生的余数范围必在0~4之间。所以,对正整数进行模a的取余运算,得到的余数范围在0~a-1,如果对取余运算的结果加上b,得到的结果就在b~a+b-1之间。所以,我们要得到[M,N]区间内的随机数,函数rand()就要对(N-M+1)取余运算,再加上M。

    编写一个输出包含100个[1,10]区间内整数的随机序列产生程序。

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

int main(){
    int num;
    srand(time(0));
    printf("A set of random numbers:\n");
    for(int i = 0; i < 100; i++){
        num = rand()%10+1;
        printf("%d ",num);
    }
    putchar('\n');
    return 0;
}

编译并执行两次:

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言中构造随机数原理及rand()取余构造随机数方法 的相关文章

  • C语言学习之认识exit()函数

    C语言学习之认识exit 函数 在C语言的main函数中我们通常使用return 0 exit 0 表示程序正常退出 exit exit 1 表示程序异常退出 exit 结束当前进程 当前程序 在整个程序中 只要调用 exit 就结束 但在
  • 解决复制粘贴出现的错误

    proc2 c 49 5 错误 程序中有游离的 240 proc2 c 49 5 错误 程序中有游离的 302 proc2 c 49 5 错误 程序中有游离的 240 proc2 c 49 5 错误 程序中有游离的 302 proc2 c
  • 构造函数属性为protected或者private时

    在c 中 不仅限于c 一个函数被声明为protected或者private时 那也就意味着不能被外部直接调用了 类的成员函数add 是private class cla private int add int a int b return
  • C语言中构造随机数原理及rand()取余构造随机数方法

    在C语言中 ANSIC C程序库提供rand 函数来产生随机数 但事实上 rand 是并不是一个真正的随机数产生器 即可以预测随机序列的顺序 在默认随机种子情况下产生0 99之间的随机数 其随机序列为 83 86 77 15 比如以下程序
  • C或C++文件操作大全

    文件的打开操作 fopen 打开一个文件 文件的关闭操作 fclose 关闭一个文件 文件的读写操作 fgetc 从文件中读取一个字符 fputc 写一个字符到文件中去 fgets 从文件中读取一个字符串 fputs 写一个字符串到文件中去
  • 利用枚举类型变量求从5种颜色球中取3个不同颜色球的取法

    利用枚举类型变量求从5种颜色球中取3个不同颜色球的取法 C程序设计 第二版 谭浩强 著 11 9 例11 3 口袋里有红 黄 蓝 白 黑5种颜色的若干个 每次从口袋中取出3个球 问得到3种不同色的球的可能取法 输出每种排列的情况 程序 在V
  • 计算字符串长度函数大全

    字符串的长度通常是指字符串中包含字符的数目 但有的时候人们需要的是 字符串所占字节的数目 常见的获取字符串长度的方法包括如下几种 1 使用sizeof获取字符串长度 sizeof的含义很明确 它用以获取 字符数组的字节数 当然包括结束符 0
  • 结构体指针变量使用方法举例

    include
  • unistd.h文件

    转载地址 http baike baidu com link url nEyMMFYevs4yoHgQUs2bcfd5WApHUKx0b1ervi7ulR09YhtqC4txmvL1Ce3FS8xTKtWQuvmEBHC9xezMGpvGH
  • 错误:Visual Studio has encountered a problem and needs to close

    我使用VS2008 Qt4 7 4开发时 安装Qt后报出该错误 google了一下解决了问题 原来在安装QT插件不正确导致的 在360软件管家中 卸载了qt win opensource 4 7 4 vs2008 但qt vs addin
  • 一组整数的全排列【C程序】

    include iostream using namespace std int myfactorial int n int i factorial i 1 factorial 1 while i lt n factorial factor
  • c++的默认拷贝构造函数,从深度拷贝和浅拷贝说起

    本文收录于微信公众号 LinuxOK ID为 Linux ok 关注公众号第一时间获取更多技术学习文章 1 c 类的默认拷贝构造函数的弊端 c 类的中有两个特殊的构造函数 1 无参构造函数 2 拷贝构造函数 它们的特殊之处在于 1 当类中没
  • CT2A

    1 CString转为char char szAsciiIP 64 memcpy szAsciiIP CT2A m pEncoder gt m strIP sizeof szAsciiIP 2 详见MSDN http msdn micros
  • C++中new与delete问题学习

    C 中new与delete问题学习 一 new char与delete问题 1 问题程序 include
  • C/C++基于线程的并发编程(二):线程安全和线程锁

    线程安全 所谓线程安全不是指线程的安全 而是指内存的安全 线程是由进程所承载 所有线程均可访问进程的上下文 意味着所有线程均可访问在进程中的内存空间 这也是线程之间造成问题的潜在原因 当多个线程读取同一片内存空间 变量 对象等 时 不会引起
  • 让bat批处理以管理员权限运行的实现方法

    1 第一种方法 有的电脑是非管理员登录 运行程序时 需要提示是否运行运行 解决方法如下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 echooff 1 2 ver find 5 gt nul goto Admin
  • VS2008如何打开memory窗口

    VS2008如何打开memory窗口 1 在想要观察的变量处设置断点 2 运行工程至断点处 3 debug gt windows gt memory 4 将变量名称复制至memory的address处 按enter键即可 5 右击内存显示去
  • C++中的typeInfo用法总结

    最近在做测试 在大型程序中 模板类型加上继承关系搞得我混乱 还好有tpyeinfo帮助捋顺关系 typeInfo与typeid简单总结说明 和sizeof这类的操作符一样 typeid是C 的关键字之一 typeid操作符的返回结果是名为t
  • VS2008错误Error spawning 'cmd.exe'的解决方法

    解决方法 In the Options go into Projects and Solutions gt VC Directories page and place this rows SystemRoot System32 System
  • C++设计模式-State状态模式

    State状态模式作用 当一个对象的内在状态改变时允许改变其行为 这个对象看起来像是改变了其类 UML图如下 State类 抽象状态类 定义一个接口以封装与Context的一个特定状态相关的行为 ConcreteState类 具体状态 每一

随机推荐

  • php使用smtp发送邮件,php使用smtp发送邮件

    include class phpmailer php 包含phpmailer类 mail new PHPMailer 建立邮件发送类 mail gt IsSMTP 设定使用SMTP方式寄信 mail gt CharSet gb2312 邮
  • freemark生成pdf

    freemark生成pdf 字体库 simsun ttc 解决中文问题 生成pdf param params param templPath param ftlName param htmlPath param pdfPath param
  • d3d制作场景地形

    一般可以先用d3d做地形的mesh 比如做一个100 100的网格 然后用photoshop做高度图 然后再程序里读取高度图数据 让mesh的每个顶点对应一个高度 http download csdn net source 855296 这
  • Backdrop Filter

    CSS 滤镜 backdrop filter backdrop filter属性允许我们使用css对元素后面的内容应用过滤效果 滤镜 名称 方法案例 效果 blur 模糊 blur 5px brightness 亮度 brightness
  • 启动失败java.lang,java.lang.RuntimeException:启动失败

    I am trying to record audio in one of my Activities using MediaRecorder Part of the code is shown below File file new Fi
  • 2021-01-15

    文章目录 SQL server基础学习5 查询 重点和难点 续 8 模糊查询 9 聚合函数 SQL server基础学习5 查询 重点和难点 续 8 模糊查询 定义 在对所需条件不太了解时将匹配条件的所有可能给查询出来 例如 我想找一个人
  • webgl 裁剪空间 投影矩阵 透视除法 Z值反转 鼠标点击位置求射线

    webgl 裁剪空间 投影矩阵 透视除法 Z值反转的讲解 右手坐标系Z值转换为深度值的过程理解 透视投影的输出结果一屏幕方向理解 朝向屏幕里为1 屏幕朝外为 1 投影矩阵的裁剪是剔除Z值不在 1到1区间的坐标 此时的 1 和深度缓冲的0对应
  • 一文读懂高速互联的阻抗及反射

    一文读懂高速互联的阻抗及反射 一文读懂高速互联的阻抗及反射 何为电阻 何为阻抗 何为特性阻抗 无损传输线 PCB上的传输线的特性阻抗 一文读懂高速互联的阻抗及反射 自建号 2021年1月1日 以来 已经过去了相当长的时间 当初暗自定下的更新
  • RM奖励模型用到的Elo评分系统

    你现在是大学教授 请详细讲述Elo排名 用公式表示 二 积分计算公式 Ra A玩家当前的Rating Rb B玩家当前的Rating Sa 实际胜负值 胜 1 平 0 5 负 0 Ea 预期A选手的胜负值 Ea 1 1 10 Rb Ra 4
  • Springboot + Mybatis 同时支持多类数据库SQL的解决方案

    pg Oracle MySQL 的字符串转日志函数不同 可通过 databaseId 来判断该执行哪段SQL 多余的代码就不写上了 直接根据下列代码就能理解
  • Linux下获取线程TID的方法——gettid()

    2013 01 07 wcdj 如何获取进程的PID process ID 可以使用 include
  • 基于OpenCV细胞识别计数

    OpenCV提供了充分的对外接口 可以方便的进行图像识别 用到的函数有 cvSmooth 图像过滤 这里用到的是高斯平滑 void cvSmooth const CvArr src CvArr dst int smoothtype CV G
  • NLP中的预训练语言模型(三)—— XL-Net和Transformer-XL

    本篇带来XL Net和它的基础结构Transformer XL 在讲解XL Net之前需要先了解Transformer XL Transformer XL不属于预训练模型范畴 而是Transformer的扩展版 旨在解决Transforme
  • 第14章 web前端开发小白学爬虫结束语

    老猿学爬虫应该是2019年7月初开始的 到现在2个多月了 有段时间了 这部分一直是老猿期待能给大家带来收获的 因为老猿爬虫实战应用的场景与网上老猿已知的场景基本都不一样 是从复用网站登录会话信息来开发应用的 如果要从网站登录开始写应该也可以
  • python kafkaconsumer_python kafka 使用

    Producer和Consumer usr bin env python import threading logging time import multiprocessing from kafka import KafkaConsume
  • Vue3 nextTick 源码分析

    Vue3 nextTick 源码分析 vue版本 3 2 37 前言 在之前的Vue2分析中 提到了Vue2的nextTick是维护了一个callbacks数组 每次更新过程中只插入一个微任务 执行放在callbacks数组中的回调 而Vu
  • ARDUINO+NRF24L01源码

    ARDUINO NRF24L01源码 NRF24L01中文说明书 英文说明书 此源码基于正点原子的NRF24L01源文件移植 NRF24L01寄存器操作命令 define NRF READ REG 0x00 读配置寄存器 低5位为寄存器地址
  • 跨链的三种模式:公证人模式、侧链/中继、哈希锁定

    对许多区块链爱好者来说 跨链是一个全新的概念 什么是跨链 跨链是如何实现的 侧链和中继链这些是什么意思呢 今天 白话区块链就来解释一下这些看似非常深奥的名词 01什么是跨链 区块链之间互通性的问题一直限制了区块链的应用空间 而跨链机制可以通
  • MyBatis 如何实现一个多对多的关联查询呢?

    转自 MyBatis 如何实现一个多对多的关联查询呢 下文将通过示例的方式 讲述多对多的关联查询 如下所示 例 一个订单可以有多种商品 一种商品可以对应多个订单 订单与商品就是多对多的级联关系 可以使用一个中间表 订单记录表 将多对多级联转
  • C语言中构造随机数原理及rand()取余构造随机数方法

    在C语言中 ANSIC C程序库提供rand 函数来产生随机数 但事实上 rand 是并不是一个真正的随机数产生器 即可以预测随机序列的顺序 在默认随机种子情况下产生0 99之间的随机数 其随机序列为 83 86 77 15 比如以下程序