Ren01010 2022-06-23 12:30 采纳率: 100%
浏览 472
已结题

为什么C语言long double类型会打印为0.000000?

未入门初学者,在最新版vscode上用gcc编译C语言,代码如下:
#include <stdio.h>
int main(void)
{
double a=5.555555555555;
long double b=5.555555555555;
printf("%f\n", a);
printf("%f\n", b);
}
运行数遍,输出皆为:
5.555556
0.000000
改为“%lf",输出为:
5.555556
0.000000
改为"%le",输出为:
5.555556e+000
3.172866e-317
为什么一遇到long double类型就这样呢?想不明白,求指点!

  • 写回答

4条回答 默认 最新

  • 关注
        printf("%.12Lf\n", b);
        __mingw_printf("%.12Lf\n", b); //windows clang64 用ucrt运行时库
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 7月1日
  • 已采纳回答 6月23日
  • 修改了问题 6月23日
  • 创建了问题 6月23日

悬赏问题

  • ¥15 shape_predictor_68_face_landmarks.dat
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制