C++ 将双精度数舍入到小数点后两位

问题描述 投票:0回答:8

我无法将 GPA 四舍五入到小数点后两位。 (例如 GPA 需要四舍五入:3.67924)我目前正在使用 ceil 进行四舍五入,但它目前将其输出为整数(368)

这就是我现在拥有的

if (cin >> gpa) {
    if (gpa >= 0 && gpa <= 5) {
           // valid number

           gpa = ceil(gpa * 100);

           break;
    } else {
           cout << "Please enter a valid GPA (0.00 - 5.00)" << endl;
           cout << "GPA: ";

    }
}

将上面的代码与 3.67924 一起使用将输出 368 (这是我想要的,但只是没有整数和小数之间的句点)。我该如何解决这个问题?

c++ rounding cin ceil
8个回答
46
投票

要将双精度数四舍五入到小数点后两位,您可以使用:

#include <iostream>
#include <cmath>

int main() {
    double value = 0.123;
    value = std::ceil(value * 100.0) / 100.0;
    std::cout << value << std::endl; // prints 0.13
    return 0;
}

要四舍五入到小数点后 n 位,您可以使用:

double round_up(double value, int decimal_places) {
    const double multiplier = std::pow(10.0, decimal_places);
    return std::ceil(value * multiplier) / multiplier;
}

此方法不会特别快,如果性能成为问题,您可能需要其他解决方案。


15
投票

如果只是写入屏幕的问题,则使用四舍五入数字

std::cout.precision(3);
std::cout << gpa << std::endl;

看到

浮点不能精确表示,因此通过内部舍入该值,然后在计算中使用它会增加不精确性。


6
投票

当您尝试在变量中存储最多 n 个十进制值时。 您必须将该值乘以 10^n,然后除以 10^n。 然后在程序中使用类型运算符进行操作。 这是示例:-

 float a,b,c,d,sum;

 cin>>a>>b>>c>>d; // reading decimal values

sum=(a*b*c*d);

sum=round(sum*100)/100; // here it is for 2 decimal points

if((float)sum < (float) 9.58)
  cout<<"YES\n";
else
  cout<<"NO\n";  

5
投票

不能将双精度数四舍五入到小数点后两位。双精度数没有小数位。它们有二进制位,并且不能与小数位相通。

如果您想要小数位,则必须使用小数基数,例如使用 printf("%.2f", ...) 格式化输出时。


2
投票

试试这个。但是您的

cout
语句处于 else 条件下,因此它不会给出 3.67924 所需的输出。

if (cin >> gpa)
{     
    if (gpa >= 0 && gpa <= 5) {
        // valid number

        gpa = ceil(gpa * 100);
        gpa=gpa/100;
        break;
    } 
    else
    {    
       cout << "Please enter a valid GPA (0.00 - 5.00)" << endl;    
       cout << "GPA: ";
    }
}

2
投票

示例:您希望将 56.899999999999 输出为带有 2 个小数点的字符串,即 56.89。

首先,转换它们
值 = 56.89 * 1000 = 5689
系数 = 100
- 1 位小数 = 10
- 2 位小数 = 100
- 3 位小数 = 1000
等等

int integerValue;
int decimal;
std::string result;
function ( int value , int factor)
{
    integerValue= (value / factor) * factor; //(5689 / 100) * 100 = 5600
    decimal = value - integerValue;  // 5689 - 5600;
    result = std::to_string((int)(value/factor) + "." + std::to_string(decimal); 
    // result = "56" + "." + "89" 
    // lastly, print result
}

不确定这是否有帮助?


0
投票

这可以通过固定和 set precision() 的组合来完成。

 cout << fixed << setprecision(2);
 cout << gpa;

-1
投票
std::string precision_2(float number)
{
    int decimal_part = (number * 100) - ((int)number * 100);
    if (decimal_part > 10) {
        return std::to_string((int)number) + "." + std::to_string(decimal_part);
    } else {
        return std::to_string((int)number) + ".0" + std::to_string(decimal_part);
    }
}

能够很好地处理所有正浮子。稍作修改即可使其也适用于 -ves。

© www.soinside.com 2019 - 2024. All rights reserved.