浅谈随机数发生器(C语言)

版权声明:本文为博主原创文章,未经博主同意不得转载。 https://blog.csdn.net/svitter/article/details/30971395

本文出自:点击打开链接


本来在做数据结构课程设计。。想用随机数生成測试数据,然后看到随机数就情不自禁的想到精度问题。想到精度问题又想到随机数生成的时间问题,想到时间问题又想到调用系统随机数生成问题。。呵呵呵呵呵。

C语言调用Linux系统随机数:linux C程序中获取shell脚本输出

C语言往里写就好说了(Linux)//不太对,正在改;

另外在Google比較难以訪问的前提下,Baidu的文章最好搜到第一个。然后依照文章名再搜一下。这样就找到原文了。


rand()%n产生区间的(0,n)的随机数,可是受RAND_MAX的限制,而RAND_MAX顾名思义就是能够生成的最大随机数,可能仅仅有32767。

因此採取的方案:

所需随机数 = int(rand()/double(RAND_MAX) * (n-1) + 1);

另外:

产生一定范围随机数的通用表示公式
要取得[a,b)的随机整数,使用(rand() % (b-a))+ a;
要取得[a,b]的随机整数,使用(rand() % (b-a+1))+ a;
要取得(a,b]的随机整数,使用(rand() % (b-a))+ a + 1;
通用公式:a + rand() % n。当中的a是起始值。n是整数的范围。
要取得a到b之间的随机整数。另一种表示:a + (int)b * rand() / (RAND_MAX + 1)。
要取得0~1之间的浮点数,能够使用rand() / double(RAND_MAX)。

另一篇关于怎样运行的文章:大于RAND_MAX的随机数 

猜你喜欢

转载自www.cnblogs.com/ldxsuanfa/p/10911047.html