float或double转换为int时的精度问题,如何避免?

例如,当输入float或double类型的数78.88776时,将其变成int类型并乘以1e5后,再转为2进制码时,得到11110000101111110000111,这串数字再转回为十进制时为7888775,与想要获得的正确数字有1的误差,应如何避免呢?

补充:
可以用个笨办法自己写个四舍五入

   int i = 0;  
    if(f>0) //正数  
      i = (f*10 + 5)/10;  
    else if(f<0) //负数  
      i = (f*10 - 5)/10;  
    else i = 0;  
  
    return i;  
阅读 7.4k
2 个回答

無法避免

不要在需要精確十進制數的時候用浮點數

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题