91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++如何實現生成隨機數

發布時間:2020-08-01 14:58:21 來源:億速云 閱讀:201 作者:小豬 欄目:編程語言

這篇文章主要講解了C++如何實現生成隨機數,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

C風格

C為隨機數提供的工具是rand、srand和RAND_MAX,定義在<stdlib.h>中。

srand為rand設置種子,如果不設置,相當于調用過srand(1)。rand產生偽隨機數,其范圍為0到RAND_MAX,RAND_MAX至少是32767,在MSVC和GCC中這個值都是32767。

偽隨機數看似隨機,實則是有規律可循的,對于相同的種子值,rand產生的序列完全相同,也就是說無論你給srand一個什么數字,多次運行程序的結果都將相同——除非你給srand的是不同的數字,比如時間。<time.h>中的time函數返回整數表示的系統時間,可用于設置種子。

如果我們只需要0到9的隨機數,可以把rand的返回值% 10;如果是42到233,可以寫rand() % 192 + 42。下面的random函數封裝了這項工作。注意只有在b - a + 1遠小于或整除RAND_MAX時隨機數的分布才比較均勻。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int random(int a, int b)
{
  return rand() % (b - a + 1) + a;
}

int main()
{
  srand(time(NULL));
  printf("RAND_MAX = %d\n", RAND_MAX);
  for (int i = 0; i < 10; i++)
    printf("%d ", rand());
  printf("\n");
  int count[10] = {0};
  for (int i = 0; i < 10000; i++)
    count[random(0, 9)]++;
  for (int i = 0; i < 10; i++)
  {
    printf("%d: ", i);
    for (int j = 0; j < count[i] / 10; j++)
      printf("*");
    printf("\n");
  }
}

C++風格

從C++11開始,C++標準規定了隨機數設施,包括均勻隨機位生成器(Uniform random bit generators,URBG)和隨機數分布等,定義在<random>中。

URBG分為隨機數引擎、引擎適配器、預置隨機數生成器和非確定隨機數生成器4類,通常后兩類就夠用了。

標準規定了3種隨機數引擎:

  • 線性同余linear_congruential_engine(LCG),時間空間消耗都少;
  • 梅森旋轉mersenne_twister_engine(MT),占用較多內存(在PC上可以忽略),計算量較大;
  • 帶進位減法(屬于滯后斐波那契生成器,LFG)subtract_with_carry_engine,性能與效果折中。

隨機數引擎都需要一個種子,生成的都是偽隨機數。

引擎適配器可以套一個隨機數引擎:

  • discard_block_engine在連續若干個偽隨機數中選擇若干個;
  • independent_bits_engine把位數多的偽隨機數壓縮成位數少的;
  • shuffle_order_engine把連續若干個偽隨機數重排。

套娃的方式是模板,理論上你還可以用適配器套適配器,不過CPU可能會有意見。

隨機數引擎的模板參數怎么取?標準定義了一些數學家們發現的效果良好的隨機數引擎:LCG minstd_rand0、minstd_rand、knuth_b;MT mt19937、mt19937_64;LFG ranlux24_base、ranlux48_base、ranlux24、ranlux48。如果你還是無從下手,那就用default_random_engine,編譯器的開發者們為你選好了他們認為最合適的,在MSVC中是mt19937,在GCC中是minstd_rand0。

以上工具都生成偽隨機數,標準還定義了真·隨機數引擎random_device,盡管標準也允許它是偽隨機的。如果它是真隨機的,那么使用起來它的效果無疑是最好的,但是多次調用后性能會急劇下降,通常只用于生成偽隨機數引擎的種子。

隨機數生成器類型都定義了靜態方法min和max,返回生成的隨機數的范圍,以及無參數的函數調用運算符operator(),返回隨機數。

#include <iostream>
#include <random>

int main()
{
  auto engine = std::default_random_engine(std::random_device()());
  std::cout << "min = " << engine.min() << "; max = " << engine.max() << std::endl;
  std::cout << "random numbers: ";
  for (int i = 0; i != 10; ++i)
    std::cout << engine() << ' ';
  std::cout << std::endl;
}

大多數情況下我們不需要min到max范圍的整數,而需要一定分布的整數或實數。標準規定了許多隨機數分布類型,我數學不好,不太懂這些。

  • 均勻分布uniform_int_distribution、uniform_real_distribution;
  • 伯努利分布bernoulli_distribution、binomial_distribution、negative_binomial_distribution、geometric_distribution;
  • 泊松分布poisson_distribution、exponential_distribution、gamma_distribution、weibull_distribution、extreme_value_distribution;
  • 正態分布normal_distribution、lognormal_distribution、chi_squared_distribution、cauchy_distribution、fisher_f_distribution、student_t_distribution;

抽樣分布discrete_distribution、piecewise_constant_distribution、piecewise_linear_distribution。

構造分布實例時傳入分布的參數。調用operator()獲得結果,參數為隨機數引擎。

#include <iostream>
#include <random>
#include <string>

int main()
{
  auto engine = std::default_random_engine(std::random_device()());
  std::uniform_int_distribution<int> uniform(0, 9);
  int count[10] = {0};
  for (int i = 0; i != 10000; ++i)
    ++count[uniform(engine)];
  for (int i = 0; i != 10; ++i)
    std::cout << i << ": " << std::string(count[i] / 10, '*') << std::endl;
}

注意,與STL中左閉右開的習慣不同,uniform_int_distribution構造函數接受的參數是閉區間。

看完上述內容,是不是對C++如何實現生成隨機數有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蓝田县| 资源县| 马公市| 西畴县| 黄梅县| 井陉县| 铜山县| 阿拉善盟| 界首市| 叙永县| 曲靖市| 梓潼县| 淳化县| 汉源县| 莆田市| 正镶白旗| 瓦房店市| 苏州市| 黎平县| 绵阳市| 江永县| 绥德县| 武隆县| 淄博市| 白银市| 黄龙县| 峨山| 克东县| 宁远县| 论坛| 阜新市| 尤溪县| 旌德县| 龙江县| 扎赉特旗| 兴安盟| 铅山县| 青州市| 泗水县| 驻马店市| 江永县|