鱼C论坛

 找回密码
 立即注册
查看: 2745|回复: 3

[技术交流] 一个实现四舍五入的程序

[复制链接]
发表于 2014-9-21 16:10:31 | 显示全部楼层 |阅读模式
50鱼币
别人问我个简单程序的原理,结果还给问住了
就是问下面这个代码实现四舍五入,0.565算完是0.56  0.665算完是0.67
将float改成double就解决了,可我想知道用float为毛是这样

  1. <DIV> #include   <stdio.h>
  2. void main()
  3. {
  4. float h,s;
  5. int k;
  6. h=0.565;//要四舍五入的值
  7. k=h*1000;
  8. k%=10;
  9. if(k>=5)//四舍五入的判断
  10. {
  11.   k=h*100+1;
  12. }
  13. else
  14. {
  15.   k=h*100;
  16. }
  17. s=k/100.0;
  18. printf("%f\n",s);</DIV>
  19. <DIV> </DIV>
  20. <DIV> h=0.665;//第二个要四舍五入的值
  21. k=h*1000;
  22. k%=10;
  23. if(k>=5)
  24. {
  25.   k=h*100+1;
  26. }
  27. else
  28. {
  29.   k=h*100;
  30. }
  31. s=k/100.0;
  32. printf("%f\n",s);
  33. }
  34. </DIV>
复制代码
QQ截图20140921160826.png

最佳答案

查看完整内容

楼上正解,因为计算机使用的是二进制,而十进制小数转化二进制的时候如果出现无限循环,或者长度太长以致该数据类型无法装下,就会出现精度丢失的情况。根据不同的情况,可能比原数略大,或者略小,这时候就会发生楼主的问题。楼主用计算器算一下就知道了,0.565和0.665都是无限循环的,这样精度丢失是难免的。正因为如此,我们判断一个float型数据是否等于0的时候,往往并不是判断f==0,而是判断fabs(f)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-9-21 16:10:32 | 显示全部楼层
楼上正解,因为计算机使用的是二进制,而十进制小数转化二进制的时候如果出现无限循环,或者长度太长以致该数据类型无法装下,就会出现精度丢失的情况。根据不同的情况,可能比原数略大,或者略小,这时候就会发生楼主的问题。楼主用计算器算一下就知道了,0.565和0.665都是无限循环的,这样精度丢失是难免的。正因为如此,我们判断一个float型数据是否等于0的时候,往往并不是判断f==0,而是判断fabs(f)<=1e-7
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-9-23 21:12:35 | 显示全部楼层
这么多天还是0回复:mad:
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-9-24 01:59:57 | 显示全部楼层
本帖最后由 Κυκλοφο 于 2014-9-24 02:15 编辑

上网查了一下相关的东西,可能是单浮点数在表示很小或者很大数值时不是很准确所以在数据转换中就出现问题。
列:2.635在内存中表示为2.6349999999999998   (待考证)
所以就有你那样的问题。
小甲鱼在进制转换里也没讲,不知道说的对不对

评分

参与人数 1荣誉 +2 鱼币 +2 收起 理由
灬执着de心 + 2 + 2 你俩回答的都挺好,可只有一个最佳啊

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-28 15:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表