看下printf("%.2lf\n", 4.015);这条语句

paschen 版主 2012-04-03 11:06:23
为何输出的是4.01,而预计是要输出4.02的
难道这就是传说的浮点数精度的问题
求原因
求怎么解决
...全文
369 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
paschen 版主 2012-04-08
  • 打赏
  • 举报
回复
嗯嗯,谢谢大家的意见
nice_cxf 2012-04-05
  • 打赏
  • 举报
回复
对有些小数,用double不能精确表示的,做4舍5入的时候只是简单判断是否小于5,因此被舍掉了,当然加一个很小的数可以解决这个问题,但是这个数很难选择,小了没效果,大了可能把不应该入的入了。。。要看你输入数据的取值范围
paschen 版主 2012-04-05
  • 打赏
  • 举报
回复
内存中存的4.015其实是4.0149999999999997,肯定小于5,好像没解决办法了
paschen 版主 2012-04-04
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 的回复:]

你用函数四舍五入在输出来。
[/Quote]

我用函数四舍五入也不行
附我写的四舍五入函数的代码
double round(double d,unsigned p) //p是精确的位数
{
if(d==0.0)
return 0.0;
double n=10;
for(;p>0;p--)
n*=10;
if(d>0.0)
return (__int64)(d*n+5) / 10 / (n/10);
else
return (__int64)(d*n-5) / 10 / (n/10);
}
主函数里你输出round(4.015,2)看下
paschen 版主 2012-04-04
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]

printf不会四舍五入的,没人这么告诉你的,不要想当然哦。
[/Quote]

你自己换个数试下先
青霜无痕 2012-04-04
  • 打赏
  • 举报
回复
你可以把它乘以1000判断第三位数是不是大于等于5
paschen 版主 2012-04-04
  • 打赏
  • 举报
回复
刚刚自己调试时发现:4.015在内存中表示的数其实是4.0149999999999997
汗,应该是浮点数精度的问题导致了四舍五入出错

同样的,4.22225精确4位输出的也只是4.2222
MK 2012-04-04
  • 打赏
  • 举报
回复
应该是IEEE浮点格式的问题了~~~~好像是尾数那部分结构所致
asb2010 2012-04-03
  • 打赏
  • 举报
回复
你用函数四舍五入在输出来。
满衣兄 2012-04-03
  • 打赏
  • 举报
回复
printf不会四舍五入的,没人这么告诉你的,不要想当然哦。

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧