我做了类似的事
long double n;
cin >> n;
n = n * 10000;
long long int temp = (long long) n;
现在当我尝试打印temp时,在一些测试用例中会出现问题,例如2.36
对于2.36,temp的值应为23600,但temp的值为23599
请某人帮助我,因为这已经有4个错误的问题。小问题
简化.. 我的代码就像这样
int main()
{
int t;
for(scanf("%d", &t); t-- ;) {
float n;
scanf("%f", &n);
n *= 10000;
long int as = (long int) n;
cout << "\nas : " << as << " n : " << n << endl;
long a, b;
a = as;
b = 10000;
while(a%b != 0) {
long temp = a % b;
a = b;
b = temp;
}
long factor = b;
cout << (10000/factor) << endl;
}
return 0;
}
这个程序的目的是......给我一个数字,在小数点后最多可以有4个位置。这是击球手的平均得分,所以我们必须找到他应该打的最小比赛数来获得这个得分
答案 0 :(得分:4)
这是因为内部表示浮点的方式。在执行截断之前,您应该围绕它们。
执行floor(n+0.5)
或ceil(x-0.5)
会正确对数字进行舍入。
修改强>
由于你的截断步骤本身就是一个floor(..)操作,你应该像@Mooing Duck所说的那样n = n * 10000 + 0.5
。
(Example)