在c ++中进行类型转换时自动舍入a

时间:2013-01-15 22:13:40

标签: c++ casting type-conversion

我做了类似的事

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个位置。这是击球手的平均得分,所以我们必须找到他应该打的最小比赛数来获得这个得分

1 个答案:

答案 0 :(得分:4)

这是因为内部表示浮点的方式。在执行截断之前,您应该围绕它们。

执行floor(n+0.5)ceil(x-0.5)会正确对数字进行舍入。

修改

由于你的截断步骤本身就是一个floor(..)操作,你应该像@Mooing Duck所说的那样n = n * 10000 + 0.5

Example