C语言库函数rand()源代码】
【本程序在Dev C 4.9.9.2 下编译通过】
/*
  这两个函数是C库中产生随机数的程序。你需要先
  使用srand()函数赋随机数种子值。然后再使用
  rand()函数来产生随机数。但是产生随机数的算法
  较简单,srandom()random()函数是对这两个函数
  的改良,用法也很类似。
*/
#define RANDOM_MAX 0x7FFFFFFF
 
static long my_do_rand(unsigned long *value)
{
  /*
      这个算法保证所产生的值不会超过(2^31 - 1)
这里(2^31 - 1)就是 0x7FFFFFFF。而 0x7FFFFFFF
      等于127773 * (7^5) 2836,7^5 = 16807
      整个算法是通过:t = (7^5 * t) mod (2^31 - 1)
      这个公式来计算随机值,并且把这次得到的值得到并且计算,作为
下次计算的随机种子值。
  */
  long quotient, remainder, t;
c语言库函数
 
  quotient = *value / 127773L;
  remainder = *value % 127773L;
  t = 16807L * remainder - 2836L * quotient;
 
  if (t <= 0)
      t = 0x7FFFFFFFL;
  return ((*value = t) % ((unsigned long)RANDOM_MAX 1));
}
static unsigned long next = 1;
int my_rand(void)
{
  return my_do_rand(&next);
}
 
void my_srand(unsigned int seed)
{
  next = seed;
}
 
#include <time.h>
int main()
{
  int i;
 
  my_srand((unsigned)(time(NULL)));
  for(i=0;i<100;i )
  {
      if(i % 10 == 0)
         printf("\n");
      printf("%d\t",my_rand()%99 1);
  }
  system("pause");
  return 0;
}
 

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。