在c语言中如果要获取1~10的随机数,那么可能大部分人的想法都是通过以下代码获取:
rand()%10+1;
(虽然rand生成的是一个伪随机数,但是这边姑且认为他是真随机的吧)
但是生成1~10的概率真的是一样的吗?
不是的,下面我们来分析以下。
假如rand返回的最大值为105,那么使用上面那种方法获取的随机数那么生成1~6的概率要比生成7~10的概率要大,
看出来了吗?因为如果rand函数返回值的范围为0~99,那么使用上面的方式生成1~10的概率是一样的,但是,
现在rand返回值范围为0~105,如果rand返回100,则rand()%10+1的值为1,相当于1的概率要比其他数要大一点,
依此类推,生成1~6的概率要大一点点。
所以如果要使生成的数更随机一点,可以使用下面的代码:
#include<stdlib.h>
#include<stdio.h>
int get_rand10( void ){
int value;
int max_rand = ( ( RAND_MAX + 1 ) / 10 ) * 10 -1;
srand( (unsigned int) time(NULL) );
do{
value = rand();
}while(value > max_rand);
return value % 10 + 1;
}
一般情况下不必使用上面的方法,但是需要生成的随机数的最大值越接近于RAND_MAX,则越要考虑使用上面的方法。