随机数是经常要用到的,但是如果没有弄清楚怎样生成自己想要的状态,便经常造成麻烦,比如成为一个大程序中的难以被发现的潜在bug。
下面用多种方法生成-10~20的随机数。
(标注(C++/11)表示至少要达到C++/11标准,在VS中至少是2012版)
Way I
(C++/11)
#include <iostream>
#include <random>
using namespace std;
int main()
{
int ran[10];
uniform_int_distribution<int> u(-10, 20);
default_random_engine e;
for (int i = 0; i != 10; i++)
ran[i] = u(e);
for (auto c : ran) // for every one in the array 'ran'
cout << c << ' ';
cout << endl;
return 0;
}
Output:
- 每一遍输出结果是一样的,可以说是使用了随机数表。
- 当然这也可以改造成输出小数,这个读者可以自己尝试。
- 12行是 range for,也可以改写成正常的 for 循环,读者亦可自己尝试。
Way II
#include <iostream>
#include <random>
using namespace std;
int main()
{
int ran1[10];
int ran2[10];
static default_random_engine e;
static uniform_int_distribution<int> u(-10, 20);
for (int i = 0; i != 10; i++)
ran1[i] = u(e);
for (auto c : ran1)
cout << c << ' ';
cout << endl;
for (int i = 0; i != 10; i++)
ran2[i] = u(e);
for (auto c : ran2)
cout << c << ' ';
cout << endl;
return 0;
}
Output:
加上 static,此时两次调用输出不同(而Way I是一样的,这个读者可以试一下)。
但是每一次打开结果是一样的。
Way III
(仍然是随机数表类型的,每次结果一样)
详见我的博客 【C++ 程序】 随机数 中另一案例的 Example 1。
Way IV
(目前找到的唯一靠谱的每次结果是真正随机的的方法)
详见我的博客 【C++ 程序】 随机数 中另一案例的 Example 2。
Upgrades
- 如果要在某个范围内要排除某些数呢?
- 如果要选出来的数字不重复呢?
-
上述问题基本思路:找一个存储容器(比如vector)将不能被抽到的元素放进去,输出或者调用时判断是否是这个容器内的。详见我的博客 【C++ 程序】 随机数。
More examples
详见我的博客 【C++ 程序】 随机数。
ALL RIGHTS RESERVED © 2020 Teddy van Jerry
欢迎转载,转载请注明出处。