c语言生成1 100随机数?产生1到100的随机数 C语言
大家好,今天小编来为大家解答c语言生成1 100随机数这个问题,产生1到100的随机数 C语言很多人还不知道,现在让我们一起来看看吧!
c语言中如何生成1个0到1的随机数
C语言中生成1个0到1的随机数可以执行语句:float b=rand()/(RAND_MAX+1.0);
解析:
标准C库中函数rand()可以生成0~RAND_MAX之间的一个随机数,其中RAND_MAX是stdlib.h中定义的一个整数,它与系统有关。rand()函数没有输入参数,直接通过表达式rand()来引用;
用函数rand取得的随机数除以(RAND_MAX+1.0),即可确保得到的结果在0到1之间。ISO IEC 9899 2011(C11)标准中未规定 RAND_MAX的具体数值。但该标准规定了RAND_MAX的值应至少为32767。编程的时候,不应该对 RAND_MAX的具体数值做任何假设。
扩展资料:
相关说明:
1、因为rand()函数是按指定的顺序来产生整数,因此每次执行上面的语句都打印相同的两个值,所以说C语言的随机并不是真正意义上的随机。
2、为了使程序在每次执行时都能生成一个新序列的随机值,我们通常通过为随机数生成器提供一粒新的随机种子。函数 srand()(来自stdlib.h)可以为随机数生成器播散种子。只要种子不同rand()函数就会产生不同的随机数序列。srand()称为随机数生成器的初始化器。
3、随机种子(Random Seed)是计算机专业术语,一种以随机数作为对象的以真随机数(种子)为初始条件的随机数。一般计算机的随机数都是伪随机数,以一个真随机数(种子)作为初始条件,然后用一定的算法不停迭代产生随机数。
参考资料来源:百度百科-随机函数
参考资料来源:百度百科-RAND_MAX
C语言怎样产生一定范围的随机数
编译环境为:vs2013
产生1到3的整型随机数的代码如下:
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define max 3//这个函数的意义为:随机生成最大的数为3
#define min 1//这个函数的意义为:随机生成最小的数为1
int main()
{
int num;
srand(time(0));
num= rand()%(max- min)+ min;//这里的意义,“%”为模运算
printf("随机数为:%d
", num);
system("pause");//这个代码可以让弹出的黑框不会一下就消失
return 0;
}
扩展资料:
根据密码学原理,随机数的随机性检验可以分为三个标准:
条件一、统计学伪随机性。统计学伪随机性指的是在给定的随机比特流样本中,1的数量大致等于0的数量,同理,“10”“01”“00”“11”四者数量大致相等。类似的标准被称为统计学随机性。满足这类要求的数字在人类“一眼看上去”是随机的。
条件二、密码学安全伪随机性。其定义为,给定随机样本的一部分和随机算法,不能有效的演算出随机样本的剩余部分。
条件三、真随机性。其定义为随机样本不可重现。实际上只要给定边界条件,真随机数并不存在,可是如果产生一个真随机数样本的边界条件十分复杂且难以捕捉(比如计算机当地的本底辐射波动值),可以认为用这个方法演算出来了真随机数。
随机数分为三类:
①伪随机数:满足第一个条件的随机数。
②密码学安全的伪随机数:同时满足前两个条件的随机数。可以通过密码学安全伪随机数生成器
计算得出。
③真随机数:同时满足三个条件的随机数。
怎么用C语言生成随机数
生成1~13的随机数,随机数序列中没有重复字数
#include<stdio.h>
#include<stdlib.h>//包含rand()函数说明
#include<time.h>
#define N 13
void main( void)
{ inti, j, num[N], tmp;//用当前时间种子重置随机数生成器,使每次运行生成不同的随机数
srand((unsigned)time( NULL));
for(i=0;i<N;i++)//生成N个数
{
while(1)//生成1个数
{
tmp=N*rand()/ RAND_MAX+1;//产生随机数
for(j=0;j<i;j++)//判断是否重复
if( tmp==num[j])
break;
if(j==i)//找到1个数
{
num[i]=tmp;//入队列
break;//开始下一轮
}
} printf("%3d\t",num[i]);//打印结果
}
}
如果可以重复,去掉内循环,直接将生成的随机数存入数组。
关于c语言生成1 100随机数的内容到此结束,希望对大家有所帮助。