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

C語言隨機(jī)數(shù)生成教程(rand和srand用法)

 更新時(shí)間:2021年01月12日 09:26:06   作者:C語言中文網(wǎng)  
這篇文章主要介紹了C語言隨機(jī)數(shù)生成教程(rand和srand用法),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在實(shí)際編程中,我們經(jīng)常需要生成隨機(jī)數(shù),例如,貪吃蛇游戲中在隨機(jī)的位置出現(xiàn)食物,撲克牌游戲中隨機(jī)發(fā)牌。

在C語言中,我們一般使用 <stdlib.h> 頭文件中的 rand() 函數(shù)來生成隨機(jī)數(shù),它的用法為:

int rand (void);

void 表示不需要傳遞參數(shù)。

C語言中還有一個(gè) random() 函數(shù)可以獲取隨機(jī)數(shù),但是 random() 不是標(biāo)準(zhǔn)函數(shù),不能在 VC/VS 等編譯器通過,所以比較少用。

rand() 會(huì)隨機(jī)生成一個(gè)位于 0 ~ RAND_MAX 之間的整數(shù)。

RAND_MAX 是 <stdlib.h> 頭文件中的一個(gè)宏,它用來指明 rand() 所能返回的隨機(jī)數(shù)的最大值。C語言標(biāo)準(zhǔn)并沒有規(guī)定 RAND_MAX 的具體數(shù)值,只是規(guī)定它的值至少為 32767。在實(shí)際編程中,我們也不需要知道 RAND_MAX 的具體值,把它當(dāng)做一個(gè)很大的數(shù)來對(duì)待即可。

下面是一個(gè)隨機(jī)數(shù)生成的實(shí)例:

#include <stdio.h>
#include <stdlib.h>
int main(){
  int a = rand();
  printf("%d\n",a);
  return 0;
}

運(yùn)行結(jié)果舉例:
193

隨機(jī)數(shù)的本質(zhì)

多次運(yùn)行上面的代碼,你會(huì)發(fā)現(xiàn)每次產(chǎn)生的隨機(jī)數(shù)都一樣,這是怎么回事呢?為什么隨機(jī)數(shù)并不隨機(jī)呢?

實(shí)際上,rand() 函數(shù)產(chǎn)生的隨機(jī)數(shù)是偽隨機(jī)數(shù),是根據(jù)一個(gè)數(shù)值按照某個(gè)公式推算出來的,這個(gè)數(shù)值我們稱之為“種子”。種子和隨機(jī)數(shù)之間的關(guān)系是一種正態(tài)分布,如下圖所示:

C語言隨機(jī)數(shù)和種子之間呈正態(tài)分布

種子在每次啟動(dòng)計(jì)算機(jī)時(shí)是隨機(jī)的,但是一旦計(jì)算機(jī)啟動(dòng)以后它就不再變化了;也就是說,每次啟動(dòng)計(jì)算機(jī)以后,種子就是定值了,所以根據(jù)公式推算出來的結(jié)果(也就是生成的隨機(jī)數(shù))就是固定的。

重新播種

我們可以通過 srand() 函數(shù)來重新“播種”,這樣種子就會(huì)發(fā)生改變。srand() 的用法為:

void srand (unsigned int seed);

它需要一個(gè) unsigned int 類型的參數(shù)。在實(shí)際開發(fā)中,我們可以用時(shí)間作為參數(shù),只要每次播種的時(shí)間不同,那么生成的種子就不同,最終的隨機(jī)數(shù)也就不同。

使用 <time.h> 頭文件中的 time() 函數(shù)即可得到當(dāng)前的時(shí)間(精確到秒),就像下面這樣:

srand((unsigned)time(NULL));

有興趣的讀者請(qǐng)猛擊這里自行研究 time() 函數(shù)的用法,本節(jié)我們不再過多講解。

對(duì)上面的代碼進(jìn)行修改,生成隨機(jī)數(shù)之前先進(jìn)行播種:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main() {
  int a;
  srand((unsigned)time(NULL));
  a = rand();
  printf("%d\n", a);
  return 0;
}

多次運(yùn)行程序,會(huì)發(fā)現(xiàn)每次生成的隨機(jī)數(shù)都不一樣了。但是,這些隨機(jī)數(shù)會(huì)有逐漸增大或者逐漸減小的趨勢(shì),這是因?yàn)槲覀円詴r(shí)間為種子,時(shí)間是逐漸增大的,結(jié)合上面的正態(tài)分布圖,很容易推斷出隨機(jī)數(shù)也會(huì)逐漸增大或者減小。

生成一定范圍內(nèi)的隨機(jī)數(shù)

在實(shí)際開發(fā)中,我們往往需要一定范圍內(nèi)的隨機(jī)數(shù),過大或者過小都不符合要求,那么,如何產(chǎn)生一定范圍的隨機(jī)數(shù)呢?我們可以利用取模的方法:

int a = rand() % 10;  //產(chǎn)生0~9的隨機(jī)數(shù),注意10會(huì)被整除

如果要規(guī)定上下限:

int a = rand() % 51 + 13;  //產(chǎn)生13~63的隨機(jī)數(shù)

分析:取模即取余,rand()%51+13我們可以看成兩部分:rand()%51是產(chǎn)生 0~50 的隨機(jī)數(shù),后面+13保證 a 最小只能是 13,最大就是 50+13=63。

最后給出產(chǎn)生 13~63 范圍內(nèi)隨機(jī)數(shù)的完整代碼:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(){
  int a;
  srand((unsigned)time(NULL));
  a = rand() % 51 + 13;
  printf("%d\n",a);
  return 0;
}

連續(xù)生成隨機(jī)數(shù)

有時(shí)候我們需要一組隨機(jī)數(shù)(多個(gè)隨機(jī)數(shù)),該怎么生成呢?很容易想到的一種解決方案是使用循環(huán),每次循環(huán)都重新播種,請(qǐng)看下面的代碼:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main() {
  int a, i;
  //使用for循環(huán)生成10個(gè)隨機(jī)數(shù)
  for (i = 0; i < 10; i++) {
    srand((unsigned)time(NULL));
    a = rand();
    printf("%d ", a);
  }
  return 0;
}

運(yùn)行結(jié)果舉例:
8 8 8 8 8 8 8 8 8 8

運(yùn)行結(jié)果非常奇怪,每次循環(huán)我們都重新播種了呀,為什么生成的隨機(jī)數(shù)都一樣呢?

這是因?yàn)?,for 循環(huán)運(yùn)行速度非???,在一秒之內(nèi)就運(yùn)行完成了,而 time() 函數(shù)得到的時(shí)間只能精確到秒,所以每次循環(huán)得到的時(shí)間都是一樣的,這樣一來,種子也就是一樣的,隨機(jī)數(shù)也就一樣了。

那么,該如何解決呢?難道就沒有辦法連續(xù)生成隨機(jī)數(shù)了嗎?當(dāng)然有,我們將在《C語言連續(xù)生成多個(gè)隨機(jī)數(shù)》一節(jié)中給出一種巧妙的解決方案。

到此這篇關(guān)于C語言隨機(jī)數(shù)生成教程(rand和srand用法)的文章就介紹到這了,更多相關(guān)C語言隨機(jī)數(shù)生成內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • c語言枚舉類型enum的用法及應(yīng)用實(shí)例

    c語言枚舉類型enum的用法及應(yīng)用實(shí)例

    enum是C語言中的一個(gè)關(guān)鍵字,enum叫枚舉數(shù)據(jù)類型,枚舉數(shù)據(jù)類型描述的是一組整型值的集合,這篇文章主要給大家介紹了關(guān)于c語言枚舉類型enum用法及應(yīng)用的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • C語言指針變量作為函數(shù)參數(shù)的實(shí)現(xiàn)步驟詳解

    C語言指針變量作為函數(shù)參數(shù)的實(shí)現(xiàn)步驟詳解

    這篇文章主要介紹了C語言指針變量作為函數(shù)參數(shù)的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02
  • 如何在Qt中實(shí)現(xiàn)關(guān)于Json?的操作

    如何在Qt中實(shí)現(xiàn)關(guān)于Json?的操作

    JSON是一種輕量級(jí)數(shù)據(jù)交換格式,常用于客戶端和服務(wù)端的數(shù)據(jù)交互,不依賴于編程語言,在很多編程語言中都可以使用JSON,這篇文章主要介紹了在Qt中實(shí)現(xiàn)關(guān)于Json的操作,需要的朋友可以參考下
    2023-08-08
  • C++判斷子序列題目詳解

    C++判斷子序列題目詳解

    這篇文章主要為大家介紹了C++判斷子序列題目,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • C++11時(shí)間日期庫chrono的使用

    C++11時(shí)間日期庫chrono的使用

    chrono是C++11中新加入的時(shí)間日期操作庫,可以方便地進(jìn)行時(shí)間日期操作,本文詳細(xì)的介紹了一下如何使用,感興趣的可以了解一下
    2022-01-01
  • 貪心算法 WOODEN STICKS 實(shí)例代碼

    貪心算法 WOODEN STICKS 實(shí)例代碼

    貪心算法 WOODEN STICKS 實(shí)例代碼,需要的朋友可以參考一下
    2013-05-05
  • C++ win系統(tǒng)如何用MinGW編譯Boost庫

    C++ win系統(tǒng)如何用MinGW編譯Boost庫

    這篇文章主要介紹了C++ win系統(tǒng)如何用MinGW編譯Boost庫問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • C++ Boost Parameter超詳細(xì)講解

    C++ Boost Parameter超詳細(xì)講解

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱。Boost庫是一個(gè)可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱
    2022-11-11
  • Qt編寫地圖實(shí)現(xiàn)海量點(diǎn)位標(biāo)注

    Qt編寫地圖實(shí)現(xiàn)海量點(diǎn)位標(biāo)注

    海量點(diǎn)位標(biāo)注的出現(xiàn),是為了解決普通設(shè)備點(diǎn)超過幾百個(gè)性能極速降低的問題。本文將介紹如何通過Qt實(shí)現(xiàn)海量點(diǎn)位標(biāo)注功能,感興趣的可以了解一下
    2022-01-01
  • c++難以發(fā)現(xiàn)的bug(有趣)

    c++難以發(fā)現(xiàn)的bug(有趣)

    這篇文章主要介紹了c++難以發(fā)現(xiàn)的bug(有趣)的相關(guān)資料,需要的朋友可以參考下
    2017-10-10

最新評(píng)論