标题:小数点输出位数的问题
只看楼主
青蝶
Rank: 2
等 级:论坛游民
帖 子:160
专家分:51
注 册:2018-2-4
结帖率:92%
已结贴  问题点数: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;
搜索更多相关主题的帖子: 小数点 输出 位数 显示 int 
2018-08-30 00:21
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册: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
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
举个实际可观察到的例子吧
printf( "%+.0f, %+.0f\n", -2.5, +2.5 );
gcc输出 -2, +2;VC输出 -3, +3

2018-08-30 10:12



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-489516-1-1.html




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

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