问题描述
这就是我得到的,我不明白为什么会出现这个输出。当我将 float 更改为 int 时,它会提供正确的输出。
int delta=99999997/(float)1;
cout<<delta<<endl;
输出:
100000000
Image of ide
解决方法
当你用一个浮点数除一个整数时,这个整数会被转换成一个浮点数。
出现奇怪结果的原因是 99999997 无法以 C++ 的 float
在您的架构上使用的精度精确地表示为 32 位浮点数。
相反,当转换为浮点数时,这个数字会四舍五入到下一个 可表示的数字。而这个数字……恰好是 100000000。