DaffyTong520
DaffyTong520
2019-04-17 22:20
采纳率: 100%
浏览 1.0k

C语言 浮点类型 vs 2019 输出浮点数感觉不对?

1.定义了一个数值:2.0E30 分别使用float double long double进行定义 再使用printf打印
2. 打印发现结果各不相同???
3.

#include<stdio.h>
int main(void)
{
    /*int bg = 0XAA;*/
    float bg1 = 2.0e30;
    printf("%f\n", bg1);
    double bg2 = 2.0e30;
    printf("%f\n", bg2);
    long double bg3 = 2.0e30;
    printf("%f\n", bg3);

}

4.输出值为:
2000000030094932439753377710080.000000
2000000000000000039769249677312.000000
2000000000000000039769249677312.000000

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • weixin_42910064
    泡视界 2019-04-18 14:29
    已采纳

    浮点数精度有限,这也是浮点数不能用=判断等的原因

    点赞 评论
  • cardan88
    cardan88 2020-02-16 17:47

    %f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。
    其中:
    float,单精度浮点型,对应%f.
    double,双精度浮点型,对应%lf.
    在用于输出时:
    float类型可以使用%lf格式,但不会有任何好处。
    double类型如果使用了%f格式可能会导致输出错误。
    在用于输入时:
    double 类型使用了%f格式,会导致输入值错误。
    float类型使用double类型不仅会导致输入错误,还可能引起程序崩溃。
    所以在输入输出时,一定要区分好double和float,而使用对应的格式符号。
    记住%LF

    点赞 评论

相关推荐