C语言伪随机数的生成

在stdlib.h中,有两个函数与伪随机数的生成有关:srand和rand。C语言中,随机数表有很多列,srand函数是根据其参数(unsigned类型)来获得一个种子(seed),根据种子来设置从哪一列开始取随机数。rand无参数,返回一个相应的随机数。种子相同,则从同一列随机数中选取,rand每次选取之后会自动选取下一个随机数。以上的所说十分之抽象,但是一下程序可以清楚地解释其原理。

 

#include <stdio.h>
#include <stdlib.h>

int main(void)
{
    int seed, i;
    
    for (;;)
    {
        printf("Please input a number to set the seed:");
        scanf("%d", &seed);
        
        if (seed == 0)
            break;
        for (i = 0; i < 5; i++)
            printf ("%d\t", rand());
        printf("\n\n");
    }
    
    return 0;
}


一下是运行结果:

 


可见,如果srand设置的种子相同,则会从同一列随机数中选取。那么,究竟如何做到生成真正不同的随机数呢?

问题的关键在于种子的选取。我们的目的是要在不同的时间生成不同的随机数。因此,只要有一个只和时间有关的数,将其传递给srand,就可以达到目的了。这样的函数位于time.h头文件中。函数名即为time。调用time会返回一个和时间有关的整数,具体的用法如下:

 

/*
 * rand2.c
 * to create a list of random numbers.
 */
 
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define MAXNUM 100

int main(void)
{
    int i;
    srand((unsigned) time(NULL));
    for (i = 0; i < 10; i++)
        printf("%d\t", rand()%MAXNUM);
    
    printf("\n");
    return 0;
}


运行效果如下:

 




 

posted on 2013-09-26 22:59  you Richer  阅读(713)  评论(0编辑  收藏  举报