posts - 1,  comments - 0,  trackbacks - 0
随机数与随机种子      
      调用随机数函数 rand() 的时候, 实际得到的这个随机数并不是绝对随机的,它是以一个初始值,通过一个算法,计算出来的“伪随机数"数列,每次调用rand()时,从这个数列依次取出一个值,做为随机数。这个初始的值就是"随机数种子", 也就是说,如果随机数种子相同,计算出的随机数数列是相同的。而srandom( x) 这个函数就是初始化随机数产生器,设定随机数种子用的。给定的x的就是随机数种子。可以验证,当你多次调用srandm(x)时,如果x取值相同,则得到的随机数数列是一样的。所以,若我们每次运行程序时,要得到不同的随机数序列,就应该用不同的种子来初始化这个随机数产生器。比如说,用时间初始化它,或者用getpid(),用进程的pid号初始化,由于每次运行程序时,它的pid号一般是不同的,所以能够产生不同的随机数序列。

举例说明
在vc++中程序中用了srandom()和random(),头文件为stdlib.h,但编译出现错误error C3861: “srandom”: 找不到标识符。
  原因是现在vc++编译器的库函数中没有randomize()和random(),分别用srand()和rand()代替了。
  #include <time.h> //定义关于时间的函数  
  一般在用到time(NULL)(当前时间)函数时需要包含此头文件  
  #include <stdlib.h> //定义杂项函数及内存分配函数  
  一般在用到rand()和srand()函数时需要包含此头文件  

  函数名: random 功 能: 随机数发生器,也就是产生一个随机数  
  用 法: int random(int num);  
  产生的随机数范围为0~num-1。  

  函数名: randomize  
  功 能: 初始化随机数发生器,相当于拨随机种子  
  用 法: void randomize(void);
 
  1. #include <iostream>  
  2. #include <stdlib.h>    // Need random(), srandom()  
  3. #include <time.h>      // Need time()  
  4. #include <algorithm>   // Need sort(), copy()  
  5. #include <vector>      // Need vector  
  6.   
  7. using namespace std;  
  8.   
  9. void Display(vector<int>& v, const char* s);  
  10.   
  11. int main()  
  12. {  
  13.     // Seed the random number generator  
  14.     srand(time(NULL));  
  15.     // Construct vector and fill with random integer values  
  16.     vector<int> collection(10);  
  17.     for (int i = 0; i < 10; i++)  
  18.         collection[i] = rand() % 10000;  
  19.       
  20.     // Display, sort, and redisplay  
  21.     Display(collection, "Before sorting");  
  22.     sort(collection.begin(), collection.end());  
  23.     Display(collection, "After sorting");  
  24.     return 0;  
  25. }  
  26.   
  27. // Display label s and contents of integer vector v  
  28. void Display(vector<int>& v, const char* s)  
  29. {  
  30.     cout << endl << s << endl;  
  31.     copy(v.begin(), v.end(),ostream_iterator<int>(cout, "\t"));  
  32.     cout << endl;  
  33. }  
一般情况下可以设置当前时间为种子 srandom((int)time(0));
需要多次取随即数时,可以将上次拿到的随即数作为种子

posted on 2012-03-29 15:15 愤怒的考拉 阅读(1178) 评论(0)  编辑  收藏

只有注册用户登录后才能发表评论。


网站导航:
 
<2024年5月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

常用链接

留言簿

随笔档案

文章档案

搜索

  •  

最新评论