我无法将 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 (这是我想要的,但只是没有整数和小数之间的句点)。我该如何解决这个问题?
要将双精度数四舍五入到小数点后两位,您可以使用:
#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;
}
此方法不会特别快,如果性能成为问题,您可能需要其他解决方案。
如果只是写入屏幕的问题,则使用四舍五入数字
std::cout.precision(3);
std::cout << gpa << std::endl;
浮点不能精确表示,因此通过内部舍入该值,然后在计算中使用它会增加不精确性。
当您尝试在变量中存储最多 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";
不能将双精度数四舍五入到小数点后两位。双精度数没有有小数位。它们有二进制位,并且不能与小数位相通。
如果您想要小数位,则必须使用小数基数,例如使用 printf("%.2f", ...) 格式化输出时。
试试这个。但是您的
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: ";
}
}
示例:您希望将 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
}
不确定这是否有帮助?
这可以通过固定和 set precision() 的组合来完成。
cout << fixed << setprecision(2);
cout << gpa;
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。