C/C++中int类型变量运算结果转float/double探究

在编程中,经常用到的一个结果转换就是两个int类型变量相除的结果为了保留精确度而转换为float或者double类型,但是这个地方最容易令人犯错误的是,如果使用如下的类型转换方式,转换时是将两个int类型变量先相除得到一个int类型结果,再将这个int类型结果转换为float或者double类型,而不是直接计算保留带有精确度的结果。

int main ()
{
    int x = 50;
    int y = 12;
    
    cout << x / y << endl;
    
    cout << (float) (x / y) << endl;
    
    cout << (double) (x / y) << endl;
    
    cout << (double) x / (double) y << endl;
    
    return 0;
}

 

4
4
4
4.16667

 

posted @ 2020-03-12 00:36  MK_筱雨  阅读(4013)  评论(0编辑  收藏  举报