欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++常見(jiàn)獲取隨機(jī)數(shù)的方法小結(jié)

 更新時(shí)間:2018年05月07日 08:47:01   作者:Wayne-Zhu  
這篇文章主要介紹了C++常見(jiàn)獲取隨機(jī)數(shù)的方法,結(jié)合實(shí)例形式總結(jié)分析了C++獲取隨機(jī)數(shù)的幾種常見(jiàn)方法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下

本文實(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ì)有所幫助。

相關(guān)文章

  • 華為機(jī)試題之統(tǒng)計(jì)單詞個(gè)數(shù)實(shí)例代碼

    華為機(jī)試題之統(tǒng)計(jì)單詞個(gè)數(shù)實(shí)例代碼

    這篇文章主要介紹了華為機(jī)試題之統(tǒng)計(jì)單詞個(gè)數(shù)實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 淺談C語(yǔ)言結(jié)構(gòu)體

    淺談C語(yǔ)言結(jié)構(gòu)體

    本文主要介紹C語(yǔ)言 結(jié)構(gòu)體的知識(shí),學(xué)習(xí)C語(yǔ)言肯定需要學(xué)習(xí)結(jié)構(gòu)體,這里詳細(xì)說(shuō)明了結(jié)構(gòu)體并附示例代碼,供大家參考學(xué)習(xí),有需要的小伙伴可以參考下
    2021-10-10
  • c++ 實(shí)現(xiàn)KMP算法

    c++ 實(shí)現(xiàn)KMP算法

    這篇文章主要介紹了c++ 實(shí)現(xiàn)KMP算法的示例,幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下
    2020-10-10
  • C++數(shù)據(jù)結(jié)構(gòu)之紅黑樹(shù)的實(shí)現(xiàn)

    C++數(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-08
  • C++實(shí)現(xiàn)圖的遍歷算法(DFS,BFS)的示例代碼

    C++實(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)的使用方法

    深入了解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
  • OpenCV實(shí)現(xiàn)亂序碎片復(fù)原

    OpenCV實(shí)現(xiàn)亂序碎片復(fù)原

    這篇文章主要介紹了通過(guò)OpenCV 直方圖相似度對(duì)比,實(shí)現(xiàn)將4張打亂順序的碎片拼接復(fù)原并展示原圖。文中的示例代碼講解詳細(xì),需要的朋友可以學(xué)習(xí)一下
    2021-12-12
  • c++編譯使用log4cplus的詳細(xì)步驟

    c++編譯使用log4cplus的詳細(xì)步驟

    C++很強(qiáng)大,但是仍然有很多不盡如人意的地方,比如打印日志方面就沒(méi)有java的log4j那種信手拈來(lái),自然而然地東西,今天我們說(shuō)一說(shuō)一個(gè)很強(qiáng)大地日志庫(kù)log4cplus在c++項(xiàng)目中地使用,感興趣的朋友一起看看吧
    2023-10-10
  • 如何使用VC庫(kù)函數(shù)中的快速排序函數(shù)

    如何使用VC庫(kù)函數(shù)中的快速排序函數(shù)

    下面呢,小編就為大家介紹一下VC中庫(kù)函數(shù)qsort()的用法。需要的朋友可以過(guò)來(lái)參考下
    2013-09-09
  • C++實(shí)現(xiàn)校園運(yùn)動(dòng)會(huì)報(bào)名系統(tǒng)

    C++實(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

最新評(píng)論