自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C++產(chǎn)生隨機數(shù)具體實現(xiàn)方法詳解

開發(fā) 后端
C++產(chǎn)生隨機數(shù)的實現(xiàn)通常都是使用C++編程語言中的rand()函數(shù)來生成隨機數(shù)。不過在實際操作中還需要我們注意一些使用技巧的應(yīng)用。

C++編程語言的應(yīng)用,可以輕松的幫助開發(fā)人員實現(xiàn)各種功能需求,比如隨機數(shù)的生成等等。那么在這里我們就會給大家詳細介紹一下有關(guān)C++產(chǎn)生隨機數(shù)的具體方法,希望大家可以對此有一個詳細的了解。

C++中常用rand()函數(shù)生成隨機數(shù),但嚴(yán)格意義上來講生成的只是偽隨機數(shù)(pseudo-random integral number)。生成隨機數(shù)時需要我們指定一個種子,如果在程序內(nèi)循環(huán),那么下一次生成隨機數(shù)時調(diào)用上一次的結(jié)果作為種子。但如果分兩次執(zhí)行程序,那么由于種子相同,生成的“隨機數(shù)”也是相同的。

在工程應(yīng)用時,我們一般將系統(tǒng)當(dāng)前時間(Unix時間)作為種子,這樣C++產(chǎn)生隨機數(shù)更接近于實際意義上的隨機數(shù)。給一下例程如下:

  1. #include < iostream> 
  2. #include < ctime> 
  3. #include < cstdlib> 
  4. using namespace std;  
  5. int main()  
  6. {  
  7. double random(double,double);  
  8. srand(unsigned(time(0)));  
  9. for(int icnt = 0; icnt != 10; ++icnt)  
  10. cout < <  "No." < <  icnt+1 < <  ": " < <  
    int(random(0,10))< <  endl;  
  11. return 0;  
  12. }  
  13. double random(double start, double end)  
  14. {  
  15. return start+(end-start)*rand()/(RAND_MAX + 1.0);  
  16. }  
  17. /* 運行結(jié)果  
  18. * No.1: 3  
  19. * No.2: 9  
  20. * No.3: 0  
  21. * No.4: 9  
  22. * No.5: 5  
  23. * No.6: 6  
  24. * No.7: 9  
  25. * No.8: 2  
  26. * No.9: 9  
  27. * No.10: 6  
  28. */ 

利用這種C++產(chǎn)生隨機數(shù)的方法能不能得到完全意義上的隨機數(shù)呢?似乎9有點多哦?卻沒有1,4,7?!我們來做一個概率實驗,生成1000萬個隨機數(shù),看0-9這10個數(shù)出現(xiàn)的頻率是不是大致相同的。程序如下:

  1. #include < iostream> 
  2. #include < ctime> 
  3. #include < cstdlib> 
  4. #include < iomanip> 
  5. using namespace std;  
  6. int main()  
  7. {  
  8. double random(double,double);  
  9. int a[10] = {0};  
  10. const int Gen_max = 10000000;  
  11. srand(unsigned(time(0)));  
  12. for(int icnt = 0; icnt != Gen_max; ++icnt)  
  13. switch(int(random(0,10)))  
  14. {  
  15. case 0: a[0]++; break;  
  16. case 1: a[1]++; break;  
  17. case 2: a[2]++; break;  
  18. case 3: a[3]++; break;  
  19. case 4: a[4]++; break;  
  20. case 5: a[5]++; break;  
  21. case 6: a[6]++; break;  
  22. case 7: a[7]++; break;  
  23. case 8: a[8]++; break;  
  24. case 9: a[9]++; break;  
  25. default: cerr < <  "Error!" < <  endl; exit(-1);  
  26. }  
  27. for(int icnt = 0; icnt != 10; ++icnt)  
  28. cout < <  icnt < <  ": " < <  setw(6) < <  
    setiosflags(ios::fixed) < <  setprecision(2) < <  
    double(a[icnt])/Gen_max*100 < <  "%" < <  endl;  
  29. return 0;  
  30. }  
  31. double random(double start, double end)  
  32. {  
  33. return start+(end-start)*rand()/(RAND_MAX + 1.0);  
  34. }  
  35. /* 運行結(jié)果  
  36. * 0: 10.01%  
  37. * 1: 9.99%  
  38. * 2: 9.99%  
  39. * 3: 9.99%  
  40. * 4: 9.98%  
  41. * 5: 10.01%  
  42. * 6: 10.02%  
  43. * 7: 10.01%  
  44. * 8: 10.01%  
  45. * 9: 9.99%  
  46. */ 

可知用這種方法得到的隨機數(shù)是滿足統(tǒng)計規(guī)律的。以上就是對C++產(chǎn)生隨機數(shù)的相關(guān)方法的介紹。

【編輯推薦】

  1. C++打印地址信息實現(xiàn)方法介紹
  2. C++格式化字符串相關(guān)應(yīng)用解析
  3. C++枚舉子相關(guān)類型解析
  4. C++枚舉類型用途及定義詳解
  5. C++繼承基礎(chǔ)概念詳解
責(zé)任編輯:曹凱 來源: 博客園
相關(guān)推薦

2009-06-11 15:16:18

不重復(fù)隨機數(shù)Java

2024-01-25 11:32:21

2010-02-04 11:23:25

C++反射機制

2010-07-15 13:34:32

Perl隨機數(shù)

2011-05-24 17:08:57

rand()srand()

2009-06-17 17:37:43

Java隨機數(shù)

2010-10-09 15:35:25

MySQL rand函

2009-07-06 15:11:18

Java 隨機數(shù)

2010-02-06 11:19:33

C++獲取文件

2010-02-02 18:01:47

C++字符串替換函數(shù)

2010-10-25 16:29:45

Oracle隨機數(shù)產(chǎn)生

2011-07-08 10:32:11

Objective-C 隨機數(shù)

2009-08-12 18:17:31

C#隨機數(shù)發(fā)生器

2010-02-02 16:23:46

C++實現(xiàn)WPF動畫

2011-07-08 15:11:03

JAVA

2010-02-03 13:26:53

C++計時

2010-02-03 09:59:42

C++文件流操作

2010-03-05 16:56:42

Python綁定C++

2019-09-11 10:09:00

Java虛擬機算法

2010-02-01 14:53:42

C++屬性
點贊
收藏

51CTO技術(shù)棧公眾號