在UNIX操作系统和window的操作系统上,我们知道有一个函数rand,它就是用来产生随机数的函数API接口,那么它的原理如何实现?
如果约定a1=f(seed),an+1=f(an),那么可以得到一个序列a1,a2,a3..an,那么要制作一个伪随机函数rand,只需要让它每调用一次就返回序列的下一个元素就行。其实就是相当于第1次调用rand返回a1,第2次返回a2,…,第n次返回an,这样每次返回的数值都不一样,也就是相当于随机数了。但是其实不是真正的随机数,真正的随机数是使用物理现象产生的:比如掷钱币、骰子、转轮、使用电子元件的噪音、核裂变等等。这样的随机数发生器叫做物理性随机数发生器,它们的缺点是技术要求比较高。那到底什么是随机数呢?
随机数:随机数就是每次运行代码的时候随机产生的数,每次产生的数的值是无法确定的,返回 0 到 RANDMAX 之间的随机整数值,不包含 RANDMAX 的值,RANDMAX 的范围最少是在32767之间(int),即双字节(16位数)。若用 unsigned int 双字节是65535,四字节是4294967295的整数范围。而且 0 到 RANDMAX 每个数字被选中的概率是相同的。
原理:产生随机数的原理是根据一个值,一般称为随机种子,然后把这个种子作为参数,经过一系列的公式运算产生出一个值,这个值就是随机数。
在 C 语言当中使用随机数要用到 rand 函数和 srand 函数,
int rand():返回值为随机值,参数为空,通过 rand 函数就会产生一个随机数。
void srand(unsigned int seed):返回值为空, 就是设置随机种子的,当我们不设置随机种子的时候,默认设置的种子为 1,也就是srand(1)。
使用:
#include<stdlib.h>//得引入 stdlib.h 这个头文件 int main() { int rand_num = rand(); printf("rand_num = %d\n", rand_num); return 0; }
每次运行的结果都一样,这是为什么呢?上面已经说了,随机数产生的是有一个随机种子作为参数,然后返回一个值,而且默认的随机种子为1,所以每次产生的随机数都一样。
如果我们修改一下随机种子,会发现随机数和原来的不一样了,但是每次运行的结果还是一样:
#include<stdlib.h>//得引入 stdlib.h 这个头文件 int main() { srand(3); int rand_num = rand(); printf("rand_num = %d\n", rand_num); srand(5); rand_num = rand(); printf("rand_num = %d\n", rand_num); return 0; }
两次的输出结果不一样,我的输出结果如下:
rand_num = 50421 rand_num = 847425747
但是我们程序肯定是写好之后,不改动随机种子,然后每次产生不同的值才对啊,那我们来如何做呢?既然产生的随机值与种子有关,只要每次的随机种子不一样,那么产生的随机值也不一样,我们就可以把时间作为随机种子,因为每次运行时,时间都不一样,因此产生的随机值也不一样,因此我们可以这样:
#include<time.h> //使用 time 函数必须引入 time.h 头文件 #include<stdlib.h> int main() { srand((int)time(0)); int rand_num = rand(); printf("rand_num = %d\n", rand_num); return 0; }
这样的话,每次输出结果都不一样了。
通过上面的方法,我们可以获取不同的随机值了,但是我们一般会获取一定范围内的随机值,比如返回 0~100 之间的返回值,比如模拟骰子,随机返回 1~6 的值。那么我们该如何做呢?
我们要返回 0~6 的随机值,只需在上面返回随机值的地方对 7 取余即可:
int rand_num = rand() % 7; printf("rand_num = %d\n", rand_num);
所以我们如果要返回 0~a 的随机值,只要对 a + 1 取余即可,所以有下面的公式:
int rand_num = rand() % (a + 1);//返回 0 ~ a 的随机值
如果我们要返回 a ~ b 的随机值,公式是什么呢?因为随机数取余法只能返回 0 到某个数的随机值,所以 a ~ b 的随机值,我们可以先返回 0 ~ (b – a)的随机值,然后再加上 a 即可:
int rand_num = rand() % (b - a + 1);//1、返回 0 ~ (b - a)的随机值 rand_num = rand_num + a; //2、返回 a ~ b 的随机值
因此上面的 1 和 2 合并之后的公式为:
int rand_num = rand() % (b - a + 1) + a;//返回 a ~ b 的随机值
大家现在做这样的操作:
#include<stdlib.h> int main() { srand(2);//随机种子固定为2 for(int i = 0; i < 5; i++) { int rand_num = rand(); printf("rand_num = %d\n", rand_num);//注意输出结果 } return 0; }
既然随机种子一样,为什么输出结果不一样呢?这里得注意一下,如果程序没有结束,而且也没有重新设置过随机种子,那么系统会把上次的随机值作为下次随机函数的随机种子,因此在上面的 for 循环当中,其实每次的循环种子都不一样,怎么验证呢?先看我这里的输出结果为:
rand_num = 33614 rand_num = 564950498 rand_num = 1097816499 rand_num = 1969887316 rand_num = 140734213
我们可以把随机种子设置成其中的一个 rand_num 值,比如 33614,那么输出结果如果为 564950498 的话,那么说明在 for 循环中每次都把随机值作为下次的随机函数的随机种子了。
srand(33614); int rand_num = rand(); printf("rand_num = %d\n", rand_num);
结果:
rand_num = 564950498;
验证完毕。
arc4random() 函数:
这个函数是 C 语言封装的一个比较智能的随机函数,我们只要调用这个函数,就会产生随机数,不用设置随机种子,而且用法很简单:
int arc_rand = arc4random(); printf("arc_rand = %d\n", arc_rand);
每次的运行结果都不一样。如果要产生 a ~ b 的随机值,公式也是:
arc4random() % (b - a + 1) + a;
本文向大家介绍javascript产生随机数方法汇总,包括了javascript产生随机数方法汇总的使用技巧和注意事项,需要的朋友参考一下 1.Math.random(); 结果为0-1间的一个随机数(包括0,不包括1) 2.Math.floor(num); 参数num为一个数值,函数结果为num的整数部分。 3.Math.round(num); 参数num为一个数值,函数结果为num四舍五入后的
主要内容:随机数的本质,重新播种,生成一定范围内的随机数,连续生成随机数在实际编程中,我们经常需要生成随机数,例如,贪吃蛇游戏中在随机的位置出现食物,扑克牌游戏中随机发牌。 在C语言中,我们一般使用 <stdlib.h> 头文件中的 rand() 函数来生成随机数,它的用法为: int rand (void); void 表示不需要传递参数。 C语言中还有一个 random() 函数可以获取随机数,但是 random() 不是标准函数,不能在 VC/VS 等编译器通过
本文向大家介绍在C语言中使用对数函数的方法,包括了在C语言中使用对数函数的方法的使用技巧和注意事项,需要的朋友参考一下 C语言log()函数:返回以e为底的对数值 头文件: log() 函数返回以 e 为底的对数值,其原型为: log()用来计算以e为底的 x 的对数值,然后将结果返回。设返回值为 ret,则 如果 x 为负数或 0,则会发生错误并设置 errno 值。错误代码: EDOM:参数x
本文向大家介绍C语言/C++如何生成随机数,包括了C语言/C++如何生成随机数的使用技巧和注意事项,需要的朋友参考一下 本文分享了C语言/C++如何生成随机数的具体实现方法,供大家参考,具体内容如下 C语言/C++怎样产生随机数:这里要用到的是rand()函数, srand()函数,C语言/C++里没有自带的random(int number)函数。 (1) 如果你只要产生随机数而不需要设定范围的
本文向大家介绍C/C++产生随机数函数简单介绍,包括了C/C++产生随机数函数简单介绍的使用技巧和注意事项,需要的朋友参考一下 计算机的随机数都是由伪随机数,即是由小M多项式序列生成的,其中产生每个小序列都有一个初始值,即随机种子。(注意: 小M多项式序列的周期是65535,即每次利用一个随机种子生成的随机数的周期是65535,当你取得65535个随机数后它们又重复出现了。) 我们知道rand(
本文向大家介绍C语言随机数生成教程(rand和srand用法),包括了C语言随机数生成教程(rand和srand用法)的使用技巧和注意事项,需要的朋友参考一下 在实际编程中,我们经常需要生成随机数,例如,贪吃蛇游戏中在随机的位置出现食物,扑克牌游戏中随机发牌。 在C语言中,我们一般使用 <stdlib.h> 头文件中的 rand() 函数来生成随机数,它的用法为: void 表示不需要传递参数。