C語(yǔ)言使用rand函數(shù)生成隨機(jī)數(shù)
rand()函數(shù)
生成隨機(jī)數(shù)使用rand()函數(shù)
函數(shù)原型:
int rand (void); 頭文件<stdlib.h>
初步使用
?目前該“隨機(jī)數(shù)”貌似成功生成
生成0到99的隨機(jī)數(shù)
再次運(yùn)行
?發(fā)現(xiàn)問(wèn)題
大家有木有發(fā)現(xiàn)其實(shí)這三次的運(yùn)行結(jié)果生成的隨機(jī)數(shù)其實(shí)是一樣的,沒(méi)錯(cuò),我說(shuō)的就是三次,
第一次是41 18467 6334 26500 19169 15724 11478 29358 26962 24464,將這些數(shù)對(duì)100求余
不就是?41 67 34 0 69 24 78 58 62 64了嗎?
這些看似偶然的結(jié)果并不是精巧設(shè)計(jì)的,而是rand()函數(shù)需要一顆種子才能正確的生成我們所需要的隨機(jī)數(shù),沒(méi)有該種子那么使用rand()永遠(yuǎn)都是一樣的結(jié)果
查看rand()函數(shù)的官方文檔
?RAND_MAX的值是0x7fff,十進(jìn)制即?32767?,可見(jiàn)rand()函數(shù)只會(huì)產(chǎn)生0到32767之間的偽隨機(jī)整數(shù)
這個(gè)數(shù)字是由一個(gè)算法生成的,該算法在每次調(diào)用時(shí)返回一系列明顯無(wú)關(guān)的數(shù)字。該算法使用種子來(lái)生成序列,通過(guò)函數(shù)srand將序列初始化為特定的值。
官方指明了使用srand函數(shù)來(lái)生成一個(gè)種子
srand()函數(shù)
srand的官方介紹
發(fā)現(xiàn)srand函數(shù)原型是void srand(unsigned int seed)
,其中seed即種子的意思,所謂的種子無(wú)非就是一個(gè)無(wú)符號(hào)整型。
頭文件<stdlib.h>
初步使用srand()
?
?這次生成的隨機(jī)數(shù)與前面的確實(shí)不一樣
再次運(yùn)行
?
發(fā)現(xiàn)結(jié)果并沒(méi)有改變,這是咋回事呢?
發(fā)現(xiàn)問(wèn)題
其實(shí)沒(méi)有使用srand之前,rand函數(shù)本身就有默認(rèn)的種子,而srand只是將其默認(rèn)的種子改成了100而已,下次運(yùn)行該代碼種子還是100,只要種子不變,那么生成的隨機(jī)數(shù)永遠(yuǎn)都是與該種子對(duì)應(yīng)的,因此你要想每次運(yùn)行都可以得到不同的隨機(jī)數(shù),那就只能保證每次運(yùn)行的種子不一樣,這樣問(wèn)題就來(lái)了,種子也是要隨機(jī)的,這不就套娃了嗎?還好每次運(yùn)行的時(shí)間是不一樣的,因此只需要將生成的種子與時(shí)間掛鉤就能保證每次運(yùn)行的種子不一樣,因?yàn)闀r(shí)間包含了年月日時(shí)分秒,就保證了每一刻的時(shí)間是絕對(duì)不會(huì)相同的
解決問(wèn)題:time函數(shù)
?頭文件<time.h>
文檔中的核心內(nèi)容就是給time傳個(gè)空指針NULL進(jìn)去,它就將當(dāng)前的時(shí)間以time_t類(lèi)型進(jìn)行返回,其中time_t其實(shí)就是int,只不過(guò)被用typedef進(jìn)行了類(lèi)型重命名了而已,
小伙伴是否會(huì)有疑問(wèn)一個(gè)時(shí)間怎么以整型進(jìn)行表示呢?這里就涉及到了時(shí)間戳的概念
時(shí)間戳
時(shí)間戳: 當(dāng)前時(shí)間與計(jì)算機(jī)起始時(shí)間的差值,單位是秒。
計(jì)算機(jī)的起始時(shí)間:1970-01-01 08:00:00(北京時(shí)間)
?
?
以上所述是小編給大家介紹的C語(yǔ)言使用rand函數(shù)生成隨機(jī)數(shù),希望對(duì)大家有所幫助。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
C語(yǔ)言以數(shù)據(jù)塊的形式讀寫(xiě)文件實(shí)例代碼
本文主要介紹C語(yǔ)言中以數(shù)據(jù)塊的形式讀寫(xiě)文件,這里提供了實(shí)例代碼舉例說(shuō)明,有需要的小伙伴可以參考下2016-07-07C++中的可移植性和跨平臺(tái)開(kāi)發(fā)教程詳解
這篇文章主要為大家介紹了C++中的可移植性和跨平臺(tái)開(kāi)發(fā)教程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05C語(yǔ)言實(shí)現(xiàn)一個(gè)多線程委托模型的示例詳解
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)一個(gè)多線程委托模型,這就是一個(gè)使用C語(yǔ)言實(shí)現(xiàn)多線程委托模型的例子,其中包含boss線程和worker線程,可以處理工作線程的異常情況,需要的朋友可以參考下2023-06-06C語(yǔ)言實(shí)現(xiàn)父進(jìn)程主動(dòng)終止子進(jìn)程的方法總結(jié)
一般的情況,子進(jìn)程自己運(yùn)行完后,執(zhí)行exit 或者return 后,父進(jìn)程wait. waitpid收回子進(jìn)程,但子進(jìn)程是一個(gè)循環(huán)等待狀態(tài)不主動(dòng)退出,父進(jìn)程可以采用文中介紹的幾種方法,需要的朋友可以參考下2023-10-10Qt圖形圖像開(kāi)發(fā)之曲線圖表模塊QChart庫(kù)一個(gè)chart中顯示兩條曲線詳細(xì)方法與實(shí)例
這篇文章主要介紹了Qt圖形圖像開(kāi)發(fā)之曲線圖表模塊QChart庫(kù)一個(gè)chart中顯示兩條曲線詳細(xì)方法與實(shí)例,需要的朋友可以參考下2020-03-03OpenCV圖像算法實(shí)現(xiàn)圖像切分圖像合并示例
這篇文章主要為大家介紹了python圖像算法OpenCV實(shí)現(xiàn)圖像切分圖像合并操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06