w-haiS 2019-11-16 17:02 采纳率: 64.3%
浏览 2715
已采纳

急!!请教下c++double转换为int的问题

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

图片说明

图片说明

  • 写回答

2条回答 默认 最新

  • threenewbee 2019-11-16 17:06
    关注

    正常,浮点计算有误差,强制转换成int是抹去小数,而不是四舍五入,可以让结果加上0.5,再转换为int

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器