//使用正太分布随机数的例子
#include <iostream>
#include <string>
#include <random>
#include <ctime>
#include <cmath>
using namespace std;
int main()
{
default_random_engine e(time(0));//生成随机整数,用系统时间time(0)作为发生器种子,确保每次运行程序生成不同的随机数
normal_distribution<> n(10,2);//正态分布的分布类型
vector<unsigned> vals(20);//用来记录每个数字出现的次数
for(size_t i = 0; i != 400; ++i)//生成400个随机数
{
unsigned v = lround(n(e));//生成随机数,并将其舍入到最接近的整数,方便显示
if(v < vals.size())//只统计20个数字出现的次数
++vals[v];//统计每个数字出现的次数
}
for(size_t j = 0; j !=vals.size(); ++j)//显示结果
cout<<j<<": "<<string(vals[j], '*')<<endl;
}
结果:
上述程序主要需要注意两点:
1、需要使用一个完全随机的数作为随机整数发生器的“种子”(此处为系统时间),如果不这么做的话,每次程序运行都会得到同样的结果。
2、我们可以看到最终产生的图形不是完全正态分布(对称)的,这是符合随机特性的,如果最终结果完全对称,反而会使得我们对程序的实现发生怀疑。