如何在C++中显示固定位数的数字而不进行四舍五入

7

I have this code (very basic):

#include <iostream>
#include <iomanip>

using namespace std;
int main()
{
float   a = 0.0,
        b = 0.0,
        c = 0.0;

cout<<"Input a: ";
cin>>a;
cout<<"input b: ";
cin>>b;
cout<<endl;
c = a / b;

cout<<"Result: "<<fixed<<setprecision(2)<<c<<endl;
return 0;
}

当我输入两个数字(比如 a = 513 和 b = 791),结果显示为0.65。计算器显示正确答案是0.648。我知道这是因为我的代码将最后一位小数四舍五入了,但这不是我想要的结果。
请问如何让它保留成0.64而非0.65呢?

你应该检查 cin >> a 是否返回 true。否则,输入失败了。 - Roland Illig
2个回答

10
如果您想将该值截断为两位小数,可以将其乘以100,截断为整数,然后再除以100,如下所示:

c = a / b;
c = floor(100 * c) / 100;
cout<<"Result: "<<fixed<<setprecision(2)<<c<<endl;

Demo on ideone.


哪个库有 trunc 函数?我在 VS 2012 中使用 cmath 库,但它似乎没有这个函数。 - user2529011
@user2529011,这是<cmath>库(请参见演示,我已经添加了一个#include)。 - Sergey Kalinichenko
我已经尝试了,但它仍然不起作用。 - user2529011
错误 C3861:未找到标识符“trunc”顺便说一下,我正在使用VS2012 - user2529011
1
@user2529011 哦,我明白了,std::trunc是在C++11中添加的,而VS 2012不支持C++11。你需要用floor替换它(已编辑并更改演示)。 - Sergey Kalinichenko

3
您可以使用trunc函数将数字截断到指定的位数:
c = a / b;

// truncate past two decimals:
c = trunc(c * 100) / 100;

cout<<"Result: "<<fixed<<setprecision(2)<<c<<endl;

针对通用函数:

int trunc(double val, int digits)
{
    double pow10 = pow(10,digits);
    return trunc(val * pow10) / pow10;
}

然后使用。
cout << "Result: " << fixed << setprecision(2) << trunc(c,2) << endl;

哪个库有 trunc 函数?我在 VS 2012 中使用 cmath 库,但它似乎没有这个函数。 - user2529011
或者您可以将 double 强制转换为 int 而不使用 trunc 方法。 - ruslaniv

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接