本篇文章為大家展示了C語言中怎么生成隨機數(shù),內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設,港閘企業(yè)網(wǎng)站建設,港閘品牌網(wǎng)站建設,網(wǎng)站定制,港閘網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,港閘網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。在實際編程中,我們經(jīng)常需要生成隨機數(shù),例如,貪吃蛇游戲中在隨機的位置出現(xiàn)食物,撲克牌游戲中隨機發(fā)牌。
在C語言中,我們一般使用
intrand(void);
C語言中還有一個random()函數(shù)可以獲取隨機數(shù),但是random()不是標準函數(shù),不能在VC/VS等編譯器通過,所以比較少用。
rand()會隨機生成一個位于0~RAND_MAX之間的整數(shù)。
RAND_MAX是
下面是一個隨機數(shù)生成的實例:
#include
#include
intmain(){
inta=rand();
printf("%d\n",a);
return0;
}
運行結果舉例:
193
多次運行上面的代碼,你會發(fā)現(xiàn)每次產(chǎn)生的隨機數(shù)都一樣,這是怎么回事呢?為什么隨機數(shù)并不隨機呢?
實際上,rand()函數(shù)產(chǎn)生的隨機數(shù)是偽隨機數(shù),是根據(jù)一個數(shù)值按照某個公式推算出來的,這個數(shù)值我們稱之為“種子”。種子和隨機數(shù)之間的關系是一種正態(tài)分布,如下圖所示:
C語言隨機數(shù)和種子之間呈正態(tài)分布
種子在每次啟動計算機時是隨機的,但是一旦計算機啟動以后它就不再變化了;也就是說,每次啟動計算機以后,種子就是定值了,所以根據(jù)公式推算出來的結果(也就是生成的隨機數(shù))就是固定的。
重新播種
我們可以通過srand()函數(shù)來重新“播種”,這樣種子就會發(fā)生改變。srand()的用法為:
voidsrand(unsignedintseed);
它需要一個unsignedint類型的參數(shù)。在實際開發(fā)中,我們可以用時間作為參數(shù),只要每次播種的時間不同,那么生成的種子就不同,最終的隨機數(shù)也就不同。
使用
srand((unsigned)time(NULL));
有興趣的讀者請猛擊這里自行研究time()函數(shù)的用法,本節(jié)我們不再過多講解。
對上面的代碼進行修改,生成隨機數(shù)之前先進行播種:
#include
#include
#include
intmain(){
inta;
srand((unsigned)time(NULL));
a=rand();
printf("%d\n",a);
return0;
}
多次運行程序,會發(fā)現(xiàn)每次生成的隨機數(shù)都不一樣了。但是,這些隨機數(shù)會有逐漸增大或者逐漸減小的趨勢,這是因為我們以時間為種子,時間是逐漸增大的,結合上面的正態(tài)分布圖,很容易推斷出隨機數(shù)也會逐漸增大或者減小。
在實際開發(fā)中,我們往往需要一定范圍內(nèi)的隨機數(shù),過大或者過小都不符合要求,那么,如何產(chǎn)生一定范圍的隨機數(shù)呢?我們可以利用取模的方法:
inta=rand()%10;//產(chǎn)生0~9的隨機數(shù),注意10會被整除
如果要規(guī)定上下限:
inta=rand()%51+13;//產(chǎn)生13~63的隨機數(shù)
分析:取模即取余,rand()%51+13我們可以看成兩部分:rand()%51是產(chǎn)生0~50的隨機數(shù),后面+13保證a最小只能是13,較大就是50+13=63。
最后給出產(chǎn)生13~63范圍內(nèi)隨機數(shù)的完整代碼:
#include
#include
#include
intmain(){
inta;
srand((unsigned)time(NULL));
a=rand()%51+13;
printf("%d\n",a);
return0;
}
有時候我們需要一組隨機數(shù)(多個隨機數(shù)),該怎么生成呢?很容易想到的一種解決方案是使用循環(huán),每次循環(huán)都重新播種,請看下面的代碼:
#include
#include
#include
intmain(){
inta,i;
//使用for循環(huán)生成10個隨機數(shù)
for(i=0;i<10;i++){ srand((unsigned)time(NULL)); a=rand(); printf("%d",a); } return0; } 運行結果舉例: 8888888888 運行結果非常奇怪,每次循環(huán)我們都重新播種了呀,為什么生成的隨機數(shù)都一樣呢? 這是因為,for循環(huán)運行速度非???,在一秒之內(nèi)就運行完成了,而time()函數(shù)得到的時間只能精確到秒,所以每次循環(huán)得到的時間都是一樣的,這樣一來,種子也就是一樣的,隨機數(shù)也就一樣了。
上述內(nèi)容就是C語言中怎么生成隨機數(shù),你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
當前文章:C語言中怎么生成隨機數(shù)-創(chuàng)新互聯(lián)
URL地址:http://www.rwnh.cn/article14/cejhge.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、品牌網(wǎng)站制作、移動網(wǎng)站建設、手機網(wǎng)站建設、網(wǎng)站策劃、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容