欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

有關(guān)C++中隨機函數(shù)rand() 和srand() 的用法詳解

 更新時間:2017年01月10日 09:34:22   投稿:jingxian  
下面小編就為大家?guī)硪黄嘘P(guān)C++中隨機函數(shù)rand() 和srand() 的用法詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

一、rand()

函數(shù)名:   rand  

功   能:   隨機數(shù)發(fā)生器

用   法:   int rand(void); 

所在頭文件: stdlib.h

函數(shù)說明 :

rand()的內(nèi)部實現(xiàn)是用線性同余法做的,它不是真的隨機數(shù),因其周期特別長,故在一定

的范圍里可看成是隨機的。

rand()返回一隨機數(shù)值的范圍在0至RAND_MAX 間。RAND_MAX的范圍最少是在32767之間(int)。用

unsigned int 雙字節(jié)是65535,四字節(jié)是4294967295的整數(shù)范圍。0~RAND_MAX每個數(shù)字被選中

的機率是相同的。     

用戶未設(shè)定隨機數(shù)種子時,系統(tǒng)默認的隨機數(shù)種子為1。

rand()產(chǎn)生的是偽隨機數(shù)字,每次執(zhí)行時是相同的;若要不同,用函數(shù)srand()初始化它。

實例如下:

#include <iostream> 
using namespace std; 
#include  <stdlib.h>   
#include  <time.h>  
#define MIN 1  //隨機數(shù)產(chǎn)生的范圍   
#define MAX 10 
 
int main()   
{  
  int i;  
  srand((unsigned)time(0)); 
  cout<<"Ten random numbers from "<<MIN<< 
     " to "<<MAX<<" :/n"<<endl;   
  for(i=0; i<10; i++)     //產(chǎn)生隨機數(shù) 
  { 
    cout<<MIN + (int)MAX * rand() / (RAND_MAX + 1)<<"/t";  
  } 
  cout<<endl; 
  return  0;   
}  

二、srand()

函數(shù)名:   srand  

功   能:   初始化隨機數(shù)發(fā)生器  

用   法:   void srand(unsigned  int  seed); 

所在頭文件: stdlib.h 

函數(shù)說明:

srand()用來設(shè)置rand()產(chǎn)生隨機數(shù)時的隨機數(shù)種子。

參數(shù)seed必須是個整數(shù),通??梢岳胻ime(0)的返回值或NULL來當(dāng)做seed。

如果每次seed都設(shè)相同值,rand()所產(chǎn)生的隨機數(shù)值每次就會一樣。

實例如下:


#include <iostream> 
using namespace std; 
#include  <stdlib.h>   
#include  <time.h>  
#define MIN 0  //隨機數(shù)產(chǎn)生的范圍   
#define MAX 99 
 
int main()   
{  
  int i;  
  srand((unsigned)time(NULL)); 
  cout<<"Ten random numbers from "<<MIN<< 
     " to "<<MAX<<" :/n"<<endl;   
  for(i=0; i<10; i++)     //產(chǎn)生隨機數(shù) 
  { 
    cout<<MIN + rand() % (MAX + MIN - 1)<<"/t";  
  } 
  cout<<endl; 
  return  0;   
}  

三、rand()和srand()的關(guān)系

rand()和srand()要一起使用,其中srand()用來初始化隨機數(shù)種子,rand()用來產(chǎn)生隨機數(shù)。

因為默認情況下隨機數(shù)種子為1,而相同的隨機數(shù)種子產(chǎn)生的隨機數(shù)是一樣的,失去了隨機性的意義,所以為使每次得到的隨機數(shù)不一樣,用函數(shù)srand()初始化隨機數(shù)種子。srand()的參數(shù),用time函數(shù)值(即當(dāng)前時間),因為兩次調(diào)用rand()函數(shù)的時間通常是不同的,這樣就可以保證隨機性了。

四、產(chǎn)生一定范圍隨機數(shù)的通用表示公式

要取得[a,b)的隨機整數(shù),使用(rand() % (b-a))+ a (結(jié)果值含a不含b)。

要取得[a,b]的隨機整數(shù),使用(rand() % (b-a+1))+ a (結(jié)果值含a和b)。

要取得(a,b]的隨機整數(shù),使用(rand() % (b-a))+ a + 1 (結(jié)果值不含a含b)。

(總的來說,通用公式:a + rand() % n ;其中的a是起始值,n是整數(shù)的范圍)

要取得a到b之間的隨機整數(shù),另一種表示:a + (int)b * rand() / (RAND_MAX + 1)。

要取得0~1之間的浮點數(shù),可以使用rand() / double(RAND_MAX)。

五、產(chǎn)生相同的隨機數(shù)的原因

計算機的隨機數(shù)都是由偽隨機數(shù),即是由小M多項式序列生成的,其中產(chǎn)生每個小序列都有一個初始值,即隨機種子。(注意: 小M多項式序列的周期是65535,即每次利用一個隨機種子生成的隨機數(shù)的周期是65535,當(dāng)你取得65535個隨機數(shù)后它們又重復(fù)出現(xiàn)了。) 

我們知道rand()函數(shù)可以用來產(chǎn)生隨機數(shù),但是這不是真真意義上的隨機數(shù),是一個偽隨機數(shù),是根據(jù)一個數(shù)(我們可以稱它為種子)為基準(zhǔn)以某個遞推公式推算出來的一系列數(shù),當(dāng)這系列數(shù)很大的時候,就符合正態(tài)公布,從而相當(dāng)于產(chǎn)生了隨機數(shù),但這不是真正的隨機數(shù),當(dāng)計算機正常開機后,這個種子的值是定了的,除非你破壞了系統(tǒng)。

實例如下:

#include <iostream> 
using namespace std; 
#include <stdlib.h> 
#include <time.h> 
 
int main() 
{ 
  int i; 
  for (i=0; i<10; i++)   //產(chǎn)生10個隨機數(shù) 
  { 
    cout<<rand()<<"/t"; 
  } 
  cout<<endl; 
  return 0; 
} 

每次運行得到相同的隨機序列:

41 18467 6334  26500 19169 15724 11478                        

41 18467 6334 26500 19169 15724 11478  29358 26962 24464

為得到不同的隨機數(shù)序列,則需改變這個種子的值。方法:在開始產(chǎn)生隨機數(shù)前,調(diào)用一次srand(time(NULL))(注意:srand()一定要放在循環(huán)外面或者是循環(huán)調(diào)用的外面,否則的話得到的是相同的隨機數(shù))。

程序示例:

#include <iostream> 
using namespace std; 
#include <stdlib.h> 
#include <time.h> 
 
int main() 
{ 
  int i; 
  srand((unsigned)time(NULL)); //初始化隨機數(shù)種子 
  for (i=0; i<10; i++)     //產(chǎn)生10個隨機數(shù) 
  { 
    cout<<rand()<<"/t"; 
  } 
  cout<<endl; 
  return 0; 
} 

每次運行得到不同的隨機序列:

1294 18562 14141 18165 11910 29784 11070 13225 131 24405

1774 25714 18734 16528 20825 17189 9848 8899 2503 5375

以上這篇有關(guān)C++中隨機函數(shù)rand() 和srand() 的用法詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++標(biāo)準(zhǔn)模板庫string類的介紹與使用講解

    C++標(biāo)準(zhǔn)模板庫string類的介紹與使用講解

    今天小編就為大家分享一篇關(guān)于C++標(biāo)準(zhǔn)模板庫string類的介紹與使用講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • C語言實現(xiàn)鏈隊列代碼

    C語言實現(xiàn)鏈隊列代碼

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)鏈隊列代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 利用C++簡單實現(xiàn)順序表和單鏈表的示例代碼

    利用C++簡單實現(xiàn)順序表和單鏈表的示例代碼

    這篇文章主要給大家介紹了關(guān)于利用C++簡單實現(xiàn)順序表和單鏈表的方法,文中給出了詳細的示例代碼供大家參考學(xué)習(xí),需要的朋友可以參考借鑒,下面來跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • C++ Boost Bind庫示例分析使用

    C++ Boost Bind庫示例分析使用

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱
    2022-11-11
  • 詳解C語言中結(jié)構(gòu)體的自引用和相互引用

    詳解C語言中結(jié)構(gòu)體的自引用和相互引用

    這篇文章主要介紹了C語言中結(jié)構(gòu)體的自引用和相互引用,詳細解析了結(jié)構(gòu)體中指針的指向情況,需要的朋友可以參考下
    2016-04-04
  • C語言詳解無頭單向非循環(huán)鏈表各種操作方法

    C語言詳解無頭單向非循環(huán)鏈表各種操作方法

    無頭單向非循環(huán)鏈表:結(jié)構(gòu)簡單,一般不會單獨用來存數(shù)據(jù)。實際中更多是作為其他數(shù)據(jù)結(jié)構(gòu)的子結(jié)構(gòu),如哈希桶、圖的鄰接表等等。另外這種結(jié)構(gòu)在筆試面試中出現(xiàn)很多
    2022-04-04
  • C語言詳解實現(xiàn)猜數(shù)字游戲步驟

    C語言詳解實現(xiàn)猜數(shù)字游戲步驟

    猜數(shù)字是興起于英國的益智類小游戲,起源于20世紀中期,一般由兩個人或多人玩,也可以由一個人和電腦玩。游戲規(guī)則為一方出數(shù)字,一方猜,今天我們來實現(xiàn)這個游戲案例
    2022-07-07
  • C++基于人工智能搜索策略解決農(nóng)夫過河問題示例

    C++基于人工智能搜索策略解決農(nóng)夫過河問題示例

    這篇文章主要介紹了C++基于人工智能搜索策略解決農(nóng)夫過河問題,簡單描述了農(nóng)夫過河問題的概念、實現(xiàn)原理并結(jié)合具體實例形式給出了C++使用人工智能搜索策略解決農(nóng)夫過河問題的相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • C++中的異常實例詳解

    C++中的異常實例詳解

    異常處理是C++的一項語言機制,用于在程序中處理異常事件,下面這篇文章主要給大家介紹了關(guān)于C++中異常的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-02-02
  • 解決Visual?Studio?Code錯誤Cannot?build?and?debug?because?the

    解決Visual?Studio?Code錯誤Cannot?build?and?debug?because?

    這篇文章主要為大家介紹了解決Visual?Studio?Code錯誤Cannot?build?and?debug?because?the及分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07

最新評論