第10行%1f的意义?

来源:2-8 自动类型转换

叶素心

2016-08-04 13:15

恩...如题

写回答 关注

3回答

  • 951a115599
    2016-08-04 13:52:22
    已采纳

    %f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。
    其中:
    float,单精度浮点型,对应%f.
    double,双精度浮点型,对应%lf.

    在用于输出时:
    float类型可以使用%lf格式,但不会有任何好处。
    double类型如果使用了%f格式可能会导致输出错误。

    在用于输入时:
    double 类型使用了%f格式,会导致输入值错误。
    float类型使用double类型不仅会导致输入错误,还可能引起程序崩溃。

    所以在输入输出时,一定要区分好double和float,而使用对应的格式符号。

    叶素心

    非常感谢!

    2016-08-05 14:10:11

    共 1 条回复 >

  • 霏梧
    2016-08-04 15:18:24

    %1f -- 你用了数字1,不是字母L的小写.
    这个1的意思是输出/入总位数为1位
    1 是只读一个字符
    float a,b;
    scanf("%1f %f",&a,&b);
    输入
    12.345 67.8
    a 读 1, b读 2.345, 而后的67.8留在输入缓冲器里.
    printf("%f %f",a,b);
    1.000000 2.345000

    输出用%1f,宽度不够,程序会自动加宽,输出结果与%f 一样.

  • SCP_343
    2016-08-04 13:48:17

    是double的格式字符,用于格式化输入输出

    举例:

    double a=2.5;

    printf("%lf/n",a);

    结果输出2.500000



    SCP_34...

    就好比int用的格式字符为%d,float用的格式字符为%f,一个道理。

    2016-08-04 13:51:41

    共 1 条回复 >

C语言入门

C语言入门视频教程,带你进入编程世界的必修课-C语言

926021 学习 · 20793 问题

查看课程

相似问题