我正在学习C语言中的rand()
函数,因为我想用它来生成范围内的随机数。但是,我对以下算法的一部分有疑问。
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
const MAX = 20, MIN = 1;
srand(time(NULL));
int randNumber = rand() % (MAX - MIN + 1) + MIN;
printf("%d", randNumber);
// yeu cau nhap so
int duDoan;
printf("Moi ban du doan con so:");
scanf("%d", &duDoan);
// chay vong lap kiem tra
while(duDoan != randNumber) {
printf("Ban da sai. Moi nhap lai:");
scanf("%d", &duDoan);
}
printf("Ban da nhap dung. Dap an la: %d ", randNumber);
return 0;
}
让我感到困惑的是为什么我们必须在这一行中添加+ MIN
:
rand() % (MAX - MIN + 1) + MIN;
如果我离开它,结果将是什么?
答案 0 :(得分:2)
rand()
是介于0和RAND_MAX
之间的数字。
rand() % n
是介于0到n-1之间的数字。如果您想要一个介于0到n之间的值,则需要rand() % (n+1)
。
在您的示例中,(MAX - MIN + 1)
是要生成的整数值的 span ,而MIN
是较低的值。例如:
MIN = -10
MAX = 10
span n
:
n = (MAX - MIN + 1) = 21
这样:
rand() % n
产生从0到20的值,并且
rand() % n - MIN
是-10至+10。如果没有+1,则错误地是-10至+9。
请注意,在需要统计上高质量的随机数的情况下,通过使用%
来限制跨度是有缺陷的,并且在n
不是RAND_MAX + 1
的因素时会产生偏差。在这种情况下,(int)(n * ((double)rand() / (double)RAND_MAX))
是更好的解决方案,因此您将:
int randNumber = (int)((MAX - MIN) * ((double)rand() /
(double)RAND_MAX)) + MIN ;
请注意,这里没有+1,因为(double)rand() / (double)RAND_MAX
的范围是0到1,所以乘以n可以得到0到n 。