| 网站首页 | 业界新闻 | 群组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 编程论坛
共有 169 人关注过本帖
标题:小数点输出位数的问题
只看楼主 加入收藏
青蝶
Rank: 2
等 级:论坛游民
帖 子:147
专家分:51
注 册:2018-2-4
结帖率:93.18%
  已结贴   问题点数:20  回复次数:2   
小数点输出位数的问题
要求对ans保留两位小数(四舍五入),想问一下为什么第一种写法不对,第二种对了?

显示错误的写法:
 if(ans*100-(int)(ans*100)>=0.5) ans+=0.01;
 printf("%.2lf\n",ans);

显示正确的写法:
 if(ans*100-(int)(ans*100)==0.5) ans+=0.001; //加上这一句是因为我发现当小数点后第三位是5,其余都是零的时候,
                                             //没有四舍五入到第二位,麻烦大佬也解释一下,谢谢。
 cout<<fixed<<setprecision(2)<<ans<<endl;
2018-08-30 00:21
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:273
帖 子:6001
专家分:34319
注 册:2011-1-18
  得分:20 
这种需求本身就怪里怪气的,浮点数不是十进制形式……

即使假设浮点数能无误差表示每一个实数
对于第一段代码,如果 ans 原先为 1.365 的话,你处理后它变成了 1.375,用printf("%.2lf\n",ans)是输出1.37,还是输出1.38
你不知道,我也不知道,gcc等都是四舍六入五成双,vc是四舍五入
2018-08-30 10:08
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:273
帖 子:6001
专家分:34319
注 册:2011-1-18
  得分:0 
举个实际可观察到的例子吧
printf( "%+.0f, %+.0f\n", -2.5, +2.5 );
gcc输出 -2, +2;VC输出 -3, +3

2018-08-30 10:12







关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.033920 second(s), 9 queries.
Copyright©2004-2018, BCCN.NET, All Rights Reserved