今天在计算数据的时候,我用c++算数的时候出现了点问题,如下图,就是double 类型的d取值为1,然后N为整型20,densityC为宏定义的0.5,
结果算出来1.0*20*0.5得出数值为9???这计算机不拿我当人呢,请问大佬们这个怎么解决

急!!请教下c++double转换为int的问题
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- threenewbee 2019-11-16 17:06关注
正常,浮点计算有误差,强制转换成int是抹去小数,而不是四舍五入,可以让结果加上0.5,再转换为int
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用 1