如何产生一个不重复的随机数

这是我在写一个Linux C聊天室的项目中需要产生一个随机数作为,用户登录的ID,本来直接用rand() % 10000 产生一个随机数,发现产生的随机数每次都是一样的。于是在网上查找了资料。
先来看一个例子:

#include 
#include 

int main()
{
    int i;
    int j;

    srand((int)time(NULL));
    for(i = 0;i < 15;i++)
    {
        j = rand() % 100;//产生100以内的随机数
        printf("%d\n",j);
    }

    return 0;
}

备注:如果把第九行【srand((int)time(NULL))】注释掉,那么程序可以无错误的运行,但是每次出来的15个数都是和之前出来的15个数是一样的!所以必须把srand((int)time(NULL))加上!

函数说明 :
因为rand的内部实现是用线性同余法做的,他不是真的随机数,只不过是因为其周期特别长,所以有一定的范围里可看成是随机的,rand()会返回一随机数值,范围在0至RAND_MAX 间。在调用此函数产生随机数前,必须先利用srand()设好随机数种子,如果未设随机数种子,rand()在调用时会自动设随机数种子为1。rand()产生的是假随机数字,每次执行时是相同的。若要不同,以不同的值来初始化它.初始化的函数就是srand()。
返回值:
返回0至RAND_MAX之间的随机整数值,RAND_MAX的范围最少是在32767之间(int),即双字节(16位数)。若用unsigned int 双字节是65535,四字节是4294967295的整数范围。
0~RAND_MAX每个数字被选中的机率是相同的。

#include
main()
{
   int i,j;
   for(i=0;i<10;i++)
   {
   j=1+(int)(10.0*rand()/(RAND_MAX+1.0));
   printf("%d ",j);
   }
}

执行:
9 4 8 8 10 2 4 8 3 6
9 4 8 8 10 2 4 8 3 6

srand(设置随机数种子)
表头文件:#include
定义函数:void srand (unsigned int seed);
函数说明:
srand()用来设置rand()产生随机数时的随机数种子。参数seed必须是个整数,通常可以利用geypid()或time(0)的返回值来当做seed。如果每次seed都设相同值,rand()所产生的随机数值每次就会一样。
范例:

#include
#include
main()
{
   int i,j;
   srand((int)time(0));
   for(i=0;i<10;i++)
   {
      j=1+(int)(10.0*rand()/(RAND_MAX+1.0));
      printf(" %d ",j);
   }
}

执行:与rand范例比较

5 8 8 8 10 2 10 8 9 9
2 9 7 4 10 3 2 10 8 7

又或:
用”int x = rand() % 100;”来生成 0 到 100 之间的随机数这种方法是不或取的,比较好的做法是: j=(int)(n*rand()/(RAND_MAX+1.0))产生一个0到n之间的随机数

除以上所说的之外,补充一点就是srand这个函数一定要放在循环外面或者是循环调用的外面,否则的话得到的是相同的数字。

// crt_rand.c
// This program seeds the random-number generator
// with the time, then displays 10 random integers.
//

#include 
#include 
#include 

int main( void )
{
    int i;
   // Seed the random-number generator with current time so that
   // the numbers will be different every time we run.
   srand( (unsigned)time( NULL ) );
   // Display 10 numbers.
   for( i = 0; i < 10;i++ )
   printf( " %6d\n", rand() );

   printf("\n");

   // Usually, you will want to generate a number in a specific range,
   // such as 0 to 100, like this:
   {
      int RANGE_MIN = 0;
      int RANGE_MAX = 100;
      for (i = 0; i < 10; i++ )
      {
         int rand100 = (((double) rand() /
         (double) RAND_MAX) * RANGE_MAX + RANGE_MIN);
         printf( " %6d\n", rand100);
       }
    }
}

time()用于随机数种子

函数原型:time_t time ( time_t * timer );
time()函数表示返回1970-1-1 00:00:00 到当前时间的秒数。
用的时候这样:srand(unsigned(time(NULL)));例如产生1~10之间的随机整数
view sourceprint?
01 #include

你可能感兴趣的:(C语言)