spintf格式化double类型怎样保证小数精度准确?

milanleon 2018-01-18 10:36:45
比如以下格式化得到的buf实际上是"12.109999999999999"而不是希望的"12.11":
	double d = 12.11;
char buf[100] = { 0 };
sprintf_s(buf, "%.15f", d);

而如果去掉小数位数,使用%f的话小数位数只能保留6位,如下的buf是"12.123457"
	double d = 12.123456789;
char buf[100] = { 0 };
sprintf_s(buf, "%f", d);
...全文
377 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
ckc 2018-01-20
  • 打赏
  • 举报
回复
你自己应该知道自己需要多少位精度,在满足需要的情况下尽可能少输出 比如你举的第一个例子,实际上输出小数点后14位应该就不错了 普通应用很少有需要这么多小数位的精度要求
bocneuy 2018-01-18
  • 打赏
  • 举报
回复
sprintf_s(buf, "%.2f", d);
自信男孩 2018-01-18
  • 打赏
  • 举报
回复
double类型的数据应该用%lf输出。 精度本身就是有有效值的。
赵4老师 2018-01-18
  • 打赏
  • 举报
回复
paschen 2018-01-18
  • 打赏
  • 举报
回复
1、很多十进制浮点数在二进制本身就没法精确表示,要精确表示可用BCD等方式存储,所以浮点数本身就是会存在精度误差的 2、如果不加%.n控件符的话默认就只有那么多位,你可以通过%.n设置你希望的值
milanleon 2018-01-18
  • 打赏
  • 举报
回复
引用 3 楼 zhao4zhong1 的回复:
%.15g
赵4老师 2018-01-18
  • 打赏
  • 举报
回复
%.15g

70,020

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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