有没有办法在不使用流的情况下做到这一点?例如,像这样:
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
,它是“<a href="http://en.wikipedia.org/wiki/Double_precision" rel="nofollow">双精度浮点数的缩写”,它是 53 位)。无法手动设置浮点数的精度。
显示精度始终是输出格式的属性,而不是数字的属性。不要试图通过四舍五入来改变数字,这个操作是没有意义的。您不需要降低数字的精度,除非是出于显示目的。
double
无论您做什么,A始终具有相同的内部精度(很可能是 53 位二进制精度)。只有在以十进制形式将 double 作为文本写出时,您才能控制输出的十进制精度。所以不,您不能将二进制双精度数的精度设置为除本机精度之外的任何其他值(不包括十进制精度)。
如果您想要的只是将一个数字四舍五入到给定的小数位数,那么请查阅Phillip的答案(当然,还有john和Konrad在他们的评论中所做的修改)。但请注意,这不会改变基础类型的精度,并且所有使用此数字的计算都将以二进制双精度执行。此外,这种四舍五入的十进制数不需要在底层二进制浮点类型中精确表示。
如果您真的想执行精确的十进制运算,那么您必须寻找提供实际十进制浮点类型的第三方库。
使用此功能,但您首先需要将数字转换为wstring
.
INPUT L"6.4400"
std::wstring round(std::wstring text) {
int64_t length = text.length() - 1;
for (int64_t i = length; i >= 0; i--) {
if (text[i] != L'0') {
if (text[i] == L'.') {
text.replace(i, 1, L"");
break;
}
break;
}
text.replace(i, 1, L"");
}
return text;
}
OUTPUT L"6.44"