C++常見獲取隨機(jī)數(shù)的方法小結(jié)
本文實(shí)例講述了C++常見獲取隨機(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中定義的,如果我們希望在某個范圍內(nèi),可以使用 % 結(jié)合 / 來實(shí)現(xiàn)。
但是不難發(fā)現(xiàn),這里獲得的隨機(jī)數(shù)是唯一確定的,而不是變化的。所以,如果我們希望獲得變化的隨機(jī)數(shù),可以使用下面的方法。
方法二:
既然使用rand函數(shù)無法獲取到變化的隨機(jī)數(shù),這里就可以使用srand來實(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庫,其中time(0)是獲取從1970年開始的時間(單位:s),然后再獲取rand(),這時的rand就是隨機(jī)變化得了。 如下:

但這里獲取的值是不確定的,而如果我們希望獲得在某一范圍內(nèi)的值呢,也很簡單,如下所示:
#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ī)生成個人信息數(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
希望本文所述對大家C++程序設(shè)計(jì)有所幫助。
- C語言/C++中如何產(chǎn)生隨機(jī)數(shù)
- C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- C++編寫生成不重復(fù)的隨機(jī)數(shù)代碼
- 使用C/C++語言生成一個隨機(jī)迷宮游戲
- C++產(chǎn)生隨機(jī)數(shù)的實(shí)現(xiàn)代碼
- C++實(shí)現(xiàn)隨機(jī)生成迷宮地牢
- C++編程產(chǎn)生指定范圍內(nèi)的隨機(jī)數(shù)
- C語言/C++如何生成隨機(jī)數(shù)
- C++生成隨機(jī)數(shù)的實(shí)現(xiàn)代碼
- C++生成不重復(fù)的隨機(jī)整數(shù)
- C++中生成隨機(jī)數(shù)的方法總結(jié)
- C++隨機(jī)打亂函數(shù)的項(xiàng)目實(shí)踐
相關(guān)文章
VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理
這篇文章主要介紹了VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理,包括了dll文件的原理與具體實(shí)現(xiàn)過程,對于深入掌握VC程序設(shè)計(jì)具有很好的參考借鑒價值,需要的朋友可以參考下2014-10-10
Pipes實(shí)現(xiàn)LeetCode(195.第十行)
這篇文章主要介紹了Pipes實(shí)現(xiàn)LeetCode(195.第十行),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能
在R3層的模塊隱藏,我們需要做的就是將其該鏈表斷鏈,將某一模塊從這個雙向鏈表中摘除,這樣再調(diào)用傳統(tǒng)的API時就會搜索不到。本文重點(diǎn)給大家介紹利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能,感興趣的朋友一起看看吧2019-10-10
QT中QTableWidget加載大量數(shù)據(jù)不卡頓的解決
本文主要介紹了QT中QTableWidget加載大量數(shù)據(jù)不卡頓的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
Qt實(shí)現(xiàn)高準(zhǔn)確率的語音識別
Vosk是一個開源的語音識別工具,支持中英文及多種語言,具備離線識別能力,且不依賴互聯(lián)網(wǎng),本文就來聊聊如何使用Vosk API在C++中進(jìn)行中英文識別吧2024-11-11
C語言數(shù)組越界引發(fā)的死循環(huán)問題解決
本文主要介紹了C語言數(shù)組越界引發(fā)的死循環(huán)問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
C++ namespace相關(guān)語法實(shí)例分析
這篇文章主要介紹了C++ namespace相關(guān)語法實(shí)例分析,對C++初學(xué)者有很好的參考借鑒價值,需要的朋友可以參考下2014-08-08

