作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
基本问题,代码非常大,但我的问题是,核心是基本问题:
我有一个称为变量的 double 值,如果我用 cout << 变量检查它,它会给我,例如 982。
下一行代码是 int intvariable = variable。
然后,当我用 cout << intvariable 检查它时,我得到 981。
有趣的是,这并不总是发生。对于 985,它可能会保持在 985,但在 984 和 983 时,它将返回 983 和 982。我似乎根本无法弄清楚这一点。我试过将它转换为 float ,然后再转换为整数,或者转换为另一个 double ,然后再转换为整数。
我需要它作为一个 int,这样我就可以对它使用模数运算符。
我应该指出,之前在代码中 double 小于 1(即 0.987),然后乘以小数位数使其成为实数、正整数(尽管它存储为 double 还在那个时候)。也许这与随机舍入有关?
最佳答案
将浮点值转换为 int
会截断(返回底数)该值,这可能会导致您遇到问题,因为 float 本质上是不精确的。尝试四舍五入该数字,即 intvariable = (int)(0.5 + variable)
。您可能还对计算浮点除法余数的 fmod
函数感兴趣(请参阅 http://www.cplusplus.com/reference/cmath/)。
关于c++ - 从 double 转换为 int 时值发生变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14552079/
我是一名优秀的程序员,十分优秀!