除以 float 1 和 int 1 时显示不同的结果

问题描述

这就是我得到的,我不明白为什么会出现这个输出。当我将 float 更改为 int 时,它会提供正确的输出

int delta=99999997/(float)1;     
cout<<delta<<endl;

输出 100000000

Image of ide

解决方法

当你用一个浮点数除一个整数时,这个整数会被转换成一个浮点数。

出现奇怪结果的原因是 99999997 无法以 C++ 的 float 在您的架构上使用的精度精确地表示为 32 位浮点数。

相反,当转换为浮点数时,这个数字会四舍五入到下一个 可表示的数字。而这个数字……恰好是 100000000。