1、Linux中使用随机数
1.1、随机数和伪随机数
(1)随机数是随机出现的,没有任何规律的一组数列
(2)真正的完全随机的数列是不存在的,只是一种理想情况。我们平时使用到的随机数一般只能通过一些算法得到一个伪随机数序列
(3)我们平时说到的随机数,基本都指的是伪随机数
1.2、Linux中随机数相关API
(1)连续多次调用rand函数可以返回一个伪随机数序列
(2)srand函数可以用来设置rand 获取的伪随机序列的种子
1.3、实战
(1)单纯使用rand重复调用n次,就会得到一个0-RAND_MAX之间的伪随机数,如果需要调整范围,可以得到随机数序列后进行计算
(2)单纯使用rand来得到伪随机数序列有缺陷,每次执行程序得到的伪随机序列是同一个序列,没法得到其他序列
(3)原因是因为rand内部的算法其实是通过一个种子(seed,其实就是一个原始参数,int类型),rand内部默认是使用1作为seed的,种子一定的算法也是一定的,那么每次得到的伪随机序列肯定是同一个
(4)解决办法:换种子。用srand函数来设置种子。
#include<stdio.h>
#include<stdlib.h>
int main(void)
{
int i = 0, val = 0;
printf("RAND_MAX = %d\n", RAND_MAX);
for(i=0; i<6; i++)
{
val = rand();
printf("%d ", (val % 6)); //得到一个0-6的随机数
}
printf("\n");
return 0;
优化:
#include<stdio.h>
#include<stdlib.h>
int main(int argc, char **argv)
{
int i = 0, val = 0;
if(argc != 2)
{
printf("usage: %s num\n", argv[0]);
return -1;
}
printf("RAND_MAX = %d\n", RAND_MAX); //获取一个随机数
srand(atoi(argv[1]);
for(i=0; i<6; i++)
{
val = rand();
printf("%d ", (val % 6)); //得到一个0-6的随机数
}
printf("\n");
return 0;
总结:
(1)在每次执行程序时,先用srand设置一个不同的种子,然后再多次调用rand获取一个伪随机序列,这样就可以每次都得到一个不一样的伪随机序列
(2)一般常规做法使用time函数的返回值来做srand的参数
优化2:
#include<stdio.h>
#include<stdlib.h>
int main(int argc, char **argv)
{
int i = 0, val = 0;
/*
if(argc != 2)
{
printf("usage: %s num\n", argv[0]);
return -1;
}
*/
printf("RAND_MAX = %d\n", RAND_MAX); //获取一个随机数
srand(time(NULL));
for(i=0; i<6; i++)
{
val = rand();
printf("%d ", (val % 6)); //得到一个0-6的随机数
}
printf("\n");
return 0;