现在C语言编译器都提供了一个基于ANSI标准的伪随机数发生器函数,用来生成随机数。它们就是rand()和srand()函数。这两个函数的工作过程如下。 C语言中rand()函数可以用来生成随机数,但这不是真正意义上的随机数,是一个伪随机数,是根据一个数,我们可以称它为种子,为基准以摸个递推公式推算出来的一系数。在程序运行前这个种子就已经定了,除非你破坏了系统。 为了改变这个种子的值C语言提供了srand()函数,其原型为void srand(int a). rand()会返回一个随机数,范围在0—RAND_MAX之间。RAND_MAX定义在stdlib.h中(其值至少为32767)。在调用rand()函数前,必须先利用srand()设定好随机数种子,如果为摄 随机数种子,rand()在调用时会自动设种子为1. 一、如何产生不可预见的随机数序列 利用srand((unsigned int) time(NULL))是一种方法,因为每一次运行程序的时间是不同的。 1>首先给srand()提供一个种子,他是一个unsigned int类型其取值范围是0—65535; 2>然后调用rand(),他会根据提供给srand()的种子值返回一个随机数(在0—32767之间)。 3>根据需要多次调用rang(),从而不间断的得到随机数。 4>无论什么时候都可以给srand()提供一个新种子,从而进一步随机化rand()的输出结果。 下面是0—32767之间的随机数程序: #include<stdlib.h> #include<stdio.h> #include<time.h> //使用当前时间做种子 void main(void) { int i; srand((unisgned int)time(NULL)); //初始化随机数 for(i=0;i<10;i++) printf("%d\n",rand()); //打印10个随机数 } 根据上面的程序可以很容易的得到0—1之间的随机数 #include<stdlib.h> #include<stdio.h> #include<time.h> //使用当前时间做种子 void main(void) { int i; srand((unsigned int)time(NULL)); for(i=0;i<10;i++) printf("%5.2f\n",rand()/32767.0); } 产生1—100之间的随机数 #include<stdlib.h> #include<stdio.h> #include<time.h> //使用当前时间做种子 void main(void) { int i; srand((unsigned int)time(NULL)); for(i=0;i<10;i++) printf("%5.2f\n",rand()%100+1); } 二、如何产生设定范围内的随机数 由于rand()产生的随机数从0到rand_max,而rand_max是一个很大的数,那么如何产生从x—y的数呢? 从x—y有y-x+1个数,所以要产生从x到y的数可以这样写: k=rand()%(y-x+1)+x; 这样就可以产生你想要的任何范围随机数了。 三、产生不重复的随机数 未完待续 |
|