C++常見獲取隨機數(shù)的方法小結(jié)
本文實例講述了C++常見獲取隨機數(shù)的方法。分享給大家供大家參考,具體如下:
方法一:
使用 rand
函數(shù)可以獲取,如下。
#include<iostream> #include<ctime> using namespace std; int main() { for (int i = 0; i < 10; i++) cout << rand() << endl; return 0; }
隨機數(shù)大小是在0到RAND_MAX,值為2147483647,它是在stdlib中定義的,如果我們希望在某個范圍內(nèi),可以使用 % 結(jié)合 / 來實現(xiàn)。
但是不難發(fā)現(xiàn),這里獲得的隨機數(shù)是唯一確定的,而不是變化的。所以,如果我們希望獲得變化的隨機數(shù),可以使用下面的方法。
方法二:
既然使用rand函數(shù)無法獲取到變化的隨機數(shù),這里就可以使用srand來實現(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就是隨機變化得了。 如下:
但這里獲取的值是不確定的,而如果我們希望獲得在某一范圍內(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; }
上面的程序雖然可以得到正隨機數(shù)和負隨機數(shù),但是是交替出現(xiàn)的,還是不夠隨機,所以我們可以采用下面的方式:
#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; }
這樣,我們就可以得到真正的隨機數(shù)了,后面使用 a == -0.0 判斷是為了防止輸出 -0 的情況。 最終結(jié)果如下:
PS:這里再提供幾款相關工具供大家參考使用:
在線隨機數(shù)生成工具:
http://tools.jb51.net/aideddesign/rnd_num
在線隨機生成個人信息數(shù)據(jù)工具:
http://tools.jb51.net/aideddesign/rnd_userinfo
在線隨機字符/隨機密碼生成工具:
http://tools.jb51.net/aideddesign/rnd_password
在線隨機數(shù)字/字符串生成工具:
http://tools.jb51.net/aideddesign/suijishu
希望本文所述對大家C++程序設計有所幫助。
相關文章
C++數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實現(xiàn)
紅黑樹在表意上就是一棵每個節(jié)點帶有顏色的二叉搜索樹,并通過對節(jié)點顏色的控制,使該二叉搜索樹達到盡量平衡的狀態(tài)。本文主要為大家介紹了C++中紅黑樹的原理及實現(xiàn),需要的可以參考一下2022-08-08C++實現(xiàn)圖的遍歷算法(DFS,BFS)的示例代碼
本文給大家?guī)淼氖菆D遍歷的算法,DFS(深度優(yōu)先遍歷),BFS(廣度優(yōu)先遍歷)。這兩個算法是比較重要和常用的算法,但是在圖中的實現(xiàn)只是最基本的操作,快跟隨小編一起學習一下吧2022-07-07深入了解C++優(yōu)先隊列(priority_queue)的使用方法
在計算機科學中,優(yōu)先隊列是一種抽象數(shù)據(jù)類型,它與隊列相似,但是每個元素都有一個相關的優(yōu)先級。C++中的優(yōu)先隊列是一個容器適配器(container adapter),它提供了一種在元素之間維護優(yōu)先級的方法。本文帶你深入了解C++優(yōu)先隊列的使用方法,需要的可以參考下2023-05-05