为了账号安全,请及时绑定邮箱和手机立即绑定

第10行%1f的意义?

恩...如题

正在回答

3 回答

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

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

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

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

0 回复 有任何疑惑可以回复我~
#1

叶素心 提问者

非常感谢!
2016-08-05 回复 有任何疑惑可以回复我~

%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 一样.

0 回复 有任何疑惑可以回复我~

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

举例:

double a=2.5;

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

结果输出2.500000



0 回复 有任何疑惑可以回复我~
#1

SCP_343

就好比int用的格式字符为%d,float用的格式字符为%f,一个道理。
2016-08-04 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

第10行%1f的意义?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信