存储在具有相同积分部分的两个变量中的值不一致
Discrepancy in the value stored in two variables having the same integral part
我试图找到10^12的立方根,并在c++中使用以下代码。令我惊讶的是,返回的值是不同的。有谁能帮我解决这个问题吗?
输出:10000 9999
int y;
double x=pow(1000000000000, 1./3);
double r=floor(x);
y=(int)r;
cout<<x<<" ";
cout<<y;
您的floor
操作是这里的问题。如果返回值实际上是(由于精度误差)x = 9999.999怎么办?floor(x)
将返回9999,而cout << x
根据其内部精度设置直接打印浮点数,因此cout << x
进行隐式舍入,这就是为什么那里显示10000。
尝试将x四舍五入为整型:
int y;
double x=pow(1000000000000, 1./3);
y=(int)(x+0.5); //Proper rounding
cout<<x<<" ";
cout<<y;
return 0;
double x=pow(1000000000000, 1./3);
刚好1/3不能用double显示。
在处理双结果时至少可以说总是很有趣。0.001 + 0.001可能就是0.0
相关文章:
- 我可以创建一个包含两个变量的 for 循环,但时间复杂度仍然为 O(n) 吗?
- 命令行参数,cant 或两个变量
- 在 for 循环中更新两个变量时遇到问题C++
- C++ 编译时在两个变量之间交替
- C++ 如何在包含两个变量的结构中存储与变量不同数量的值?
- 为什么一个接一个声明的两个变量在内存中不相邻?
- 为什么动态分配的两个变量的内存位置不是连续的?
- 是否可以在C++中使用宏交换两个变量的出现?
- 计算机如何分配两个变量,我们如何计算两个变量之间的距离?
- 正确证明C 中的两个变量合理(我想将它们视为一个变量)
- 可视C 编译器将相同的存储位置提供给两个变量
- 尝试使用 {} 和 std::make_pair() 交换两个变量时的行为不同
- 在rootframework中的根文件中编写两个变量
- 最短路径,带有两个变量
- 加入两个变量和LCD打印
- 在循环中声明两个变量以逆转字符串?在C 中
- 具有两个变量的"for"循环,一个变量每次迭代递增,每隔一次迭代递增
- 如何在C++中使用一个类中两个变量的值
- 仅在C 中的一个变量上,两个变量函数的数值集成(使用数值配方库)
- 如何在我存储的两个变量之间生成随机数