C++常見(jiàn)獲取隨機(jī)數(shù)的方法小結(jié)
本文實(shí)例講述了C++常見(jiàn)獲取隨機(jī)數(shù)的方法。分享給大家供大家參考,具體如下:
方法一:
使用 rand
函數(shù)可以獲取,如下。
#include<iostream> #include<ctime> using namespace std; int main() { for (int i = 0; i < 10; i++) cout << rand() << endl; return 0; }
隨機(jī)數(shù)大小是在0到RAND_MAX,值為2147483647,它是在stdlib中定義的,如果我們希望在某個(gè)范圍內(nèi),可以使用 % 結(jié)合 / 來(lái)實(shí)現(xiàn)。
但是不難發(fā)現(xiàn),這里獲得的隨機(jī)數(shù)是唯一確定的,而不是變化的。所以,如果我們希望獲得變化的隨機(jī)數(shù),可以使用下面的方法。
方法二:
既然使用rand函數(shù)無(wú)法獲取到變化的隨機(jī)數(shù),這里就可以使用srand來(lái)實(shí)現(xiàn)了。
#include<iostream> #include<ctime> using namespace std; int main() { srand(time(0)); for (int i = 0; i < 1000; i++) cout << rand() << endl; return 0; }
這里,我們需要引入ctime
庫(kù),其中time(0)是獲取從1970年開(kāi)始的時(shí)間(單位:s),然后再獲取rand()
,這時(shí)的rand就是隨機(jī)變化得了。 如下:
但這里獲取的值是不確定的,而如果我們希望獲得在某一范圍內(nèi)的值呢,也很簡(jiǎn)單,如下所示:
#include<iostream> #include<ctime> using namespace std; int main() { srand(time(0)); for (int i = 0; i < 100; i++) cout << rand() % 100 << endl; return 0; }
如上,使用求余數(shù)的方法,我們可以獲得0 - 100之間的值。
而如果我們希望得到0 - 1之間的數(shù)呢? 如下所示:
#include<iostream> #include<ctime> using namespace std; int main() { srand(time(0)); for (int i = 0; i < 100; i++) cout << (rand() % 10) * 0.1 << endl; return 0; }
而我們希望得到-1 到 1 之間的數(shù)呢?
#include<iostream> #include<ctime> using namespace std; int main() { srand(time(0)); for (int i = 0; i < 100; i++) if (i % 2 == 0) cout << (rand() % 10) * 0.1 << endl; else cout << (rand() % 10) * -0.1 << endl; return 0; }
上面的程序雖然可以得到正隨機(jī)數(shù)和負(fù)隨機(jī)數(shù),但是是交替出現(xiàn)的,還是不夠隨機(jī),所以我們可以采用下面的方式:
#include<iostream> #include<ctime> using namespace std; int main() { srand(time(0)); double a; for (int i = 0; i < 100; i++) if (rand() % 10 > 0.4) { cout << (rand() % 10) * 0.1 << endl; } else { a = (rand() % 10) * -0.1; if (a == -0.0) { cout << 0 << endl; } else { cout << a << endl; } } return 0; }
這樣,我們就可以得到真正的隨機(jī)數(shù)了,后面使用 a == -0.0 判斷是為了防止輸出 -0 的情況。 最終結(jié)果如下:
PS:這里再提供幾款相關(guān)工具供大家參考使用:
在線隨機(jī)數(shù)生成工具:
http://tools.jb51.net/aideddesign/rnd_num
在線隨機(jī)生成個(gè)人信息數(shù)據(jù)工具:
http://tools.jb51.net/aideddesign/rnd_userinfo
在線隨機(jī)字符/隨機(jī)密碼生成工具:
http://tools.jb51.net/aideddesign/rnd_password
在線隨機(jī)數(shù)字/字符串生成工具:
http://tools.jb51.net/aideddesign/suijishu
希望本文所述對(duì)大家C++程序設(shè)計(jì)有所幫助。
- C語(yǔ)言/C++中如何產(chǎn)生隨機(jī)數(shù)
- C++產(chǎn)生隨機(jī)數(shù)的實(shí)現(xiàn)代碼
- C語(yǔ)言/C++如何生成隨機(jī)數(shù)
- C++生成隨機(jī)數(shù)的實(shí)現(xiàn)代碼
- C++實(shí)現(xiàn)產(chǎn)生隨機(jī)數(shù)和相應(yīng)的猜拳小游戲?qū)嵗a
- C++11生成隨機(jī)數(shù)(random庫(kù))的使用
- C/C++產(chǎn)生隨機(jī)數(shù)函數(shù)簡(jiǎn)單介紹
- C++隨機(jī)數(shù)生成實(shí)例講解
- C++11新特性之隨機(jī)數(shù)庫(kù)(Random?Number?Library)詳解
- C++產(chǎn)生隨機(jī)數(shù)的幾種方法小結(jié)
相關(guān)文章
華為機(jī)試題之統(tǒng)計(jì)單詞個(gè)數(shù)實(shí)例代碼
這篇文章主要介紹了華為機(jī)試題之統(tǒng)計(jì)單詞個(gè)數(shù)實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05C++數(shù)據(jù)結(jié)構(gòu)之紅黑樹(shù)的實(shí)現(xiàn)
紅黑樹(shù)在表意上就是一棵每個(gè)節(jié)點(diǎn)帶有顏色的二叉搜索樹(shù),并通過(guò)對(duì)節(jié)點(diǎn)顏色的控制,使該二叉搜索樹(shù)達(dá)到盡量平衡的狀態(tài)。本文主要為大家介紹了C++中紅黑樹(shù)的原理及實(shí)現(xiàn),需要的可以參考一下2022-08-08C++實(shí)現(xiàn)圖的遍歷算法(DFS,BFS)的示例代碼
本文給大家?guī)?lái)的是圖遍歷的算法,DFS(深度優(yōu)先遍歷),BFS(廣度優(yōu)先遍歷)。這兩個(gè)算法是比較重要和常用的算法,但是在圖中的實(shí)現(xiàn)只是最基本的操作,快跟隨小編一起學(xué)習(xí)一下吧2022-07-07深入了解C++優(yōu)先隊(duì)列(priority_queue)的使用方法
在計(jì)算機(jī)科學(xué)中,優(yōu)先隊(duì)列是一種抽象數(shù)據(jù)類型,它與隊(duì)列相似,但是每個(gè)元素都有一個(gè)相關(guān)的優(yōu)先級(jí)。C++中的優(yōu)先隊(duì)列是一個(gè)容器適配器(container adapter),它提供了一種在元素之間維護(hù)優(yōu)先級(jí)的方法。本文帶你深入了解C++優(yōu)先隊(duì)列的使用方法,需要的可以參考下2023-05-05如何使用VC庫(kù)函數(shù)中的快速排序函數(shù)
下面呢,小編就為大家介紹一下VC中庫(kù)函數(shù)qsort()的用法。需要的朋友可以過(guò)來(lái)參考下2013-09-09C++實(shí)現(xiàn)校園運(yùn)動(dòng)會(huì)報(bào)名系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)校園運(yùn)動(dòng)會(huì)報(bào)名系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10