在不使用流(ios_base::precision)的情况下设置双精度
Setting the precision of a double without using stream (ios_base::precision)
有没有一种方法可以在不使用流的情况下做到这一点?例如,类似这样的东西:
double a = 6.352356663353535;
double b = a.precision(5);
而不是:
double a = 6.352356663353535;
std::cout.precision(5);
std::cout << a << std::endl;
我是C++的新手,我很好奇。谢谢,提前。
我已经根据@john、@Konrad和@KennyTM的建议修改了代码。我已经检查过它是否适用于负数。
#include <cmath>
#include <cstdio>
using namespace std;
int main()
{
double a = 6.352356663353535;
double intpart;
double fractpart = modf (a, &intpart);
fractpart = roundf(fractpart * 100000.0)/100000.0; // Round to 5 decimal places
double b = intpart + fractpart;
printf("%.5lf", b);
}
输出
6.35236
double
s几乎普遍被实现为IEEE浮点数。它们的精度仅取决于数字大小(在double
的情况下,它是"双精度浮点数"的缩写,为53位)。无法手动设置浮点数字的精度。
显示精度始终是输出格式的属性,而不是数字的属性。不要试图通过四舍五入来改变数字,这种运算毫无意义。您不需要来降低数字的精度,除非用于显示目的。
double
无论做什么都始终具有相同的内部精度(最可能是53位二进制精度)。只有当以十进制形式将双精度写成文本时,才能控制输出的十进制精度。因此,不可以将二进制双精度数字的精度设置为其本机精度之外的任何其他精度(小数精度除外)。
如果你只想把一个数字四舍五入到给定的小数位数,那么请参阅Phillip的答案(当然,也要参考john和Konrad在评论中所做的修正)。但请注意,这不会改变底层类型的预决定,所有具有该数字的计算都将以二进制双精度执行。同样,这样一个四舍五入的十进制数不需要在底层二进制浮点类型中精确表示。
如果你真的想执行精确的十进制算术,那么你必须寻找提供实际十进制浮点类型的第三方库。
相关文章:
- 在没有太多条件句的情况下,我如何避免被零除
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 在未初始化映射的情况下,将值插入到映射的映射中
- 是默认情况下分配给char数组常量的值
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 如何在不产生任何垃圾的情况下获得C中的像素
- 在已经使用Git的情况下减少编译时间
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- 如何在没有信号的情况下从C++执行QML插槽
- 如何在不知道向量大小的情况下输入向量内部的向量?
- 为什么在某些情况下不写入此文件?
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 在没有Xcode的情况下在Mac捆绑包中嵌入框架
- UE4-如何在给定4个屏幕坐标的情况下缩放纹理或材质
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 在C++中如何在没有pow的情况下进行基础计算
- 松弛原子与无同步情况下的记忆连贯性
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 我是c ++的新手,你能解释一下在这种情况下的指针吗
- 在不使用流(ios_base::precision)的情况下设置双精度