如何随机化双精度/浮点数据类型? C++
how to randomize double/float data type? c++
我想随机化一个介于 0.03- 和 0.05 之间的值。 我知道两个数字之间有无限的值,并且 rand 采用无符号的 int 数据类型。 我想知道如何创建一个函数来随机化双精度/浮点数据类型并将限制设置为小数点后两位
我的代码如下:
double i=0.0;
double minP = 0.03;
double maxP = 0.05;
unsigned seed =time(0);
srand(seed);r
i = rand()% (maxP -minP +0.01) +minP;
%运算符不适用于双精度。生成双精度值的最佳选择是生成单个位值并将它们相加。下面是一个示例:
#include <iostream>
#include <time.h>
using namespace std;
int main() {
srand(time(0));
double random;
random = (rand() % 3) + .1*(rand() % 10) + .01*(rand() % 10);
cout.precision(2);
cout << fixed <<random;
}
此代码将生成 0.00 到 2.99 之间的随机浮点数
编辑:在考虑了大约两秒钟后,我意识到有一种更好的方法可以做到这一点。如果您只是生成一个整数,其数字等于您需要的有效数字的数量并将其除以,您将获得随机双精度。
double randDouble(double precision, double lowerBound, double upperBound) {
double random;
random = static_cast<double>(((rand()%(static_cast<int>(std::pow(10,precision)*(upperBound - lowerBound) + 1))) + lowerBound*std::pow(10,precision)))/std::pow(10,precision);
return random;
}
相关文章:
- 防止主数据类型C++的隐式转换
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 在C++中打印指向不同基元数据类型的指针的内存地址
- C++浮点数据类型和字符串数据类型无法子到模板函数中
- 如何计算数据类型的范围,例如int
- C++中数据类型修饰符的顺序
- C++LinkedList问题.数据类型之间存在冲突?没有匹配的构造函数
- 特定数据类型的模板类
- 具有多个模板的模板函数,用于特定数据类型(如字符串)?
- 有没有办法提示用户使用哪种数据类型作为模板 c++
- int数据类型的指针指向的是什么,如果是一个类的私有数据成员,我们创建了该类的两个对象?
- 时间复杂度 当具有复合数据类型(如元组或对)时?
- 如何获取C++字符数据类型的地址
- 将复杂的非基元C++数据类型转换为 Erlang/Elixir 格式,以使用 NIF 导出方法
- 构造智能点数据类型以及普通数据类型的通用方法
- 如何使映射键具有两种不同的数据类型?
- 数据类型"struct seq<0, 1, 2>{}"含义是什么?
- 如何在不破坏现有应用程序的情况下更改 API 中 stl 容器的数据类型?
- Static_cast转换为错误的数据类型,但结果仍然正确?
- 使用 Boost.Spirit 解析具有混合数据类型的 OBJ 文件?