oywoywoyw 2022-08-02 19:55 采纳率: 0%
浏览 41

double类型小数点精度

问题遇到的现象和发生背景

double类型小数点精度

问题相关代码,请勿粘贴截图

[root@localhost tmp]# cat aa.c
#include <stdio.h>
#include <stdlib.h>
void main()
{
/case 1/
printf("111 %.15f\n", 1.234567890123456 + 1e-15);

double d1;
/*case 2*/
d1 = 1.234567890123456;
d1 = d1 + 1e-15;
printf("222 %.15g\n", d1);

/*case 3*/
d1 = 1.234567890123456;
d1 = d1 + 1e-15;
printf("222 %.16g\n", d1);

}

运行结果及报错内容

[root@localhost tmp]# ./a.out
111 1.234567890123457
222 1.23456789012346
222 1.234567890123457

我的解答思路和尝试过的方法

case1和case2看起来是一样的操作,为什么同样用%.15g显示,case2丢了一位呢,正确结果是1.234567890123457,结果四舍五入为1.23456789012346了。而在case 3中改为%.16多一位显示,结果就正确了

我想要达到的结果

为什么要用%.16才正确显示15位的计算结果,是因为补码?

  • 写回答

2条回答 默认 最新

  • oywoywoyw 2022-08-02 20:02
    关注

    [root@localhost tmp]# cat main.c
    #include <stdio.h>
    #include <stdlib.h>
    void main()
    {
    printf("1e-15:%.15f\n", 1e-15);
    printf("1e-15:%.15f\n", 1.234567890123456 + 1e-15);
    double d1 = 1234567890123456789;
    printf("111 %f\n", d1);
    d1 = 1.234567890123456e+15;
    d1 = d1 + 1;
    printf("222 %.15g\n", d1);
    d1 = 1.234567890123456;
    d1 = d1 + 1e-15;
    printf("333 %.16g\n", d1);
    printf("1200000.1: %g\n", 1200000.1);
    printf("1: %g\n", 1);
    printf("1.0: %g\n", 1.0);
    }
    [root@localhost tmp]# ./a.out
    111 1.23456789012346
    222 1.23456789012346
    333 1.234567890123457
    --代码有点问题,将%.15f改为%.15g就一致了,现在看来用%.15g的话必丢一位,难道%.15要去掉一个小数点,只能表示14位小数?

    评论

报告相同问题?

问题事件

  • 创建了问题 8月2日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。