亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言中隨機(jī)數(shù)rand()函數(shù)詳解

 更新時(shí)間:2022年02月16日 14:37:50   作者:嵌入式@hxydj  
大家好,本篇文章主要講的是C語言中隨機(jī)數(shù)rand()函數(shù)詳解,感興趣的同學(xué)感快來看一看吧,對你有幫助的話記得收藏一下

  在生活中很多場景下都需要產(chǎn)生隨機(jī)數(shù),比如抽獎(jiǎng),打牌,游戲等場景下就需要使用隨機(jī)數(shù)。在C語言標(biāo)準(zhǔn)庫函數(shù)里面有專門用來產(chǎn)生隨機(jī)數(shù)的函數(shù)rand,它的函數(shù)原型如下:

  int __cdecl rand(void);

  rand函數(shù)沒有參數(shù),它的返回值就是隨機(jī)數(shù)。下面通過一個(gè)簡單的例子來測試一下rand函數(shù)。

#include <stdio.h>
#include <stdlib.h>

int main(int argc, char** argv) {
	
	int i;
		
	i = rand();

	printf("%d",i);
	return 0;
}

  直接調(diào)用rand函數(shù)產(chǎn)生一個(gè)隨機(jī)數(shù),并打印出來。運(yùn)行結(jié)果如下:

image.png

  此時(shí)生成的隨機(jī)數(shù)為41,下面多生產(chǎn)幾個(gè)隨機(jī)數(shù)看看。

image.png

  通過一個(gè)for循環(huán)產(chǎn)生10個(gè)隨機(jī)數(shù),通過打印的結(jié)果可以看到第一個(gè)隨機(jī)數(shù)是41,其他后面9個(gè)數(shù)據(jù)都比較大。將隨機(jī)次數(shù)改為15,在測試一次。

image.png

  此時(shí)產(chǎn)生了15個(gè)隨機(jī)數(shù),但是通過和產(chǎn)生10個(gè)隨機(jī)數(shù)相比可以發(fā)現(xiàn),這次產(chǎn)生的隨機(jī)數(shù)前面10個(gè)數(shù)字和上次一模一樣。將程序重新運(yùn)行之后,產(chǎn)生的隨機(jī)數(shù)和上一次也一模一樣。

  這時(shí)什么原因呢?難道隨機(jī)數(shù)生成函數(shù)rand出現(xiàn)了bug?

  實(shí)際上通過rand函數(shù)產(chǎn)生的隨機(jī)數(shù)是偽隨機(jī)數(shù),它是根據(jù)一個(gè)數(shù)值然后通過公式計(jì)算出來一個(gè)值,將計(jì)算的結(jié)果作為隨機(jī)數(shù)返回。這個(gè)固定參考的數(shù)值就被稱為“種子”,每次計(jì)算機(jī)啟動(dòng)時(shí)就會(huì)生成一個(gè)種子,然后在以后運(yùn)行的過程中種子就不會(huì)在發(fā)生變化了。所以每次執(zhí)行rnad函數(shù)的時(shí)候,它參考值種子值都是固定的,因此每次生成的隨機(jī)數(shù)也就是固定的。如果要每次生成的隨機(jī)數(shù)不同,那么每次產(chǎn)生隨機(jī)數(shù)之前就需要改變種子的值。

  種子的值是由srand函數(shù)來產(chǎn)生的,函數(shù)原型如下:

  void __cdecl srand(unsigned int _Seed);

  函數(shù)沒有返回值,它的參數(shù)就是需要設(shè)置的種子值。將修改種子的函數(shù)也添加到代碼中。

  將種子值設(shè)置為10,然后生成10個(gè)隨機(jī)數(shù)。

image.png

  將種子值設(shè)置為20,然后生成10個(gè)隨機(jī)數(shù)。

image.png

  可以看到當(dāng)種子的值發(fā)生變化后,生成的隨機(jī)數(shù)也就發(fā)生了變化。如果程序中需要重復(fù)的使用隨機(jī)的話,那么隨機(jī)種子的值就不能時(shí)一個(gè)定值,它必須時(shí)刻發(fā)生變化,這么生成的隨機(jī)數(shù)才能時(shí)刻發(fā)生變化。在系統(tǒng)中時(shí)刻發(fā)生變化的數(shù)字,首先能想到的就是時(shí)間,因?yàn)闀r(shí)間實(shí)時(shí)都在發(fā)生變化,不可能出現(xiàn)同樣的值。

  那么就可以將獲取系統(tǒng)的時(shí)間,然后作為隨機(jī)數(shù)的種子。時(shí)間函數(shù)time原型如下:

__CRT_INLINE time_t __cdecl time(time_t *_Time) { return _time64(_Time); }

  調(diào)用time函數(shù)后,它就會(huì)返回當(dāng)前系統(tǒng)的時(shí)間的秒數(shù),它的參數(shù)可以直接設(shè)置為NULL。

image.png

  調(diào)用time函數(shù)時(shí),需要添加頭文件time.h。將時(shí)間值作為隨機(jī)種子,這樣每次生成的隨機(jī)數(shù)就會(huì)不同,但是通過上面的輸出結(jié)果可以看到,每次生成的隨機(jī)數(shù)大小都變化很大,如果要將隨機(jī)數(shù)的大小控制在一定范圍內(nèi)要怎么辦呢?

  要控制數(shù)字的范圍,那么可以使用數(shù)學(xué)的取余數(shù)運(yùn)算,如果要將生成的數(shù)字控制在10以內(nèi),那么對生成的數(shù)字除以10,然后取余數(shù)。這樣余數(shù)的大小就不會(huì)超過10。

image.png

  這里對生成的隨機(jī)數(shù)除以100取余,這樣最后產(chǎn)生的隨機(jī)數(shù)都會(huì)在100以內(nèi)。

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

相關(guān)文章

  • C語言中結(jié)構(gòu)體struct編寫的一些要點(diǎn)解析

    C語言中結(jié)構(gòu)體struct編寫的一些要點(diǎn)解析

    這篇文章主要介紹了C語言中結(jié)構(gòu)體struct編寫的一些要點(diǎn)解析,談到了結(jié)構(gòu)體的聲明和指針指向等重要知識(shí)點(diǎn),需要的朋友可以參考下
    2016-04-04
  • C語言數(shù)據(jù)結(jié)構(gòu)之單鏈表與雙鏈表的增刪改查操作實(shí)現(xiàn)

    C語言數(shù)據(jù)結(jié)構(gòu)之單鏈表與雙鏈表的增刪改查操作實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了C語言數(shù)據(jù)結(jié)構(gòu)中單鏈表與雙鏈表的增刪改查操作的實(shí)現(xiàn),相信大家如果搞懂了本文內(nèi)容,應(yīng)對復(fù)雜的鏈表類的題也就能慢慢鉆研了
    2022-07-07
  • C++ 實(shí)現(xiàn)即時(shí)通信的示例代碼(直接運(yùn)行)

    C++ 實(shí)現(xiàn)即時(shí)通信的示例代碼(直接運(yùn)行)

    本文主要介紹了C++ 實(shí)現(xiàn)即時(shí)通信的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C++中類的構(gòu)造函數(shù)初始值列表解讀

    C++中類的構(gòu)造函數(shù)初始值列表解讀

    這篇文章主要介紹了C++中類的構(gòu)造函數(shù)初始值列表,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C語言常見排序算法之插入排序(直接插入排序,希爾排序)

    C語言常見排序算法之插入排序(直接插入排序,希爾排序)

    這篇文章介紹C語言常見排序算法之插入排序(直接插入排序,希爾排序),主要分享介紹的是插入排序的兩種常用算法,直接插入排序和希爾排序,需要的朋友可以參考一下
    2022-07-07
  • 一篇帶你了解C語言--位操作詳情

    一篇帶你了解C語言--位操作詳情

    這篇文章主要介紹了關(guān)于C語言位運(yùn)算的簡單示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-08-08
  • C++菱形繼承及解決方法詳解

    C++菱形繼承及解決方法詳解

    這篇文章主要介紹了C++菱形繼承及解決方法詳解,在多繼承結(jié)構(gòu)中,存在著很多問題,比如從不同基類中繼承了同名成員,派生類中也定義了同名成員,這種二義性問題很好解決,加上要訪問的基類的類名限制就可以了,需要的朋友可以參考下
    2023-08-08
  • C語言的動(dòng)態(tài)內(nèi)存分配及動(dòng)態(tài)內(nèi)存分配函數(shù)詳解

    C語言的動(dòng)態(tài)內(nèi)存分配及動(dòng)態(tài)內(nèi)存分配函數(shù)詳解

    這篇文章主要為大家詳細(xì)介紹了C語言的動(dòng)態(tài)內(nèi)存分配及動(dòng)態(tài)內(nèi)存分配函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 一篇文章帶你了解C++面向?qū)ο缶幊?-繼承

    一篇文章帶你了解C++面向?qū)ο缶幊?-繼承

    這篇文章主要介紹了解析C++面對象編程--繼承的運(yùn)用,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下,希望能夠給你帶來幫助
    2021-08-08
  • C語言實(shí)現(xiàn)簡單的圖書管理系統(tǒng)

    C語言實(shí)現(xiàn)簡單的圖書管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡單的圖書管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-03-03

最新評(píng)論