若定义float a;现要从键盘输入a数据,其整数位为3位,小数位为2位,则选用( A)
A)scanf(“%6f”,&a); B)scanf(“%5.2f”,a);
C)scanf(“%6.2f”,&a); D)scanf(“%f”,a);
为什么不是scanf("%3.2f",&a);
例子
#include<stdio.h>
#include<stdlib.h>
int main()
{
int k;
float f;
scanf("%3d%*4d%6f",&k,&f);
printf("%d%f",k,f);
return 0;
}
原来scanf不能对精度进行控制,在scanf中的%6f表示读取一个长度为6位(含小数点)的浮点型数据。
(3) scanf()函数中没有精度控制。
如: scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数为2位的实数。
所以可以得出结论:scanf和printf对数据长度的控制不同,scanf不能控制精度只能控制长度,printf可以控制长度也可以控制精度。
然后又发现了一样东西:
%*d4表示忽略一个4位的整数
于是又写了两个demo测试了一下
1.忽略前五位
#include<stdio.h>#include<stdlib.h> int main(){ int k; scanf("%*5d%d",&k);printf("%d",k); return 0; }
输入了123456后,输出结果为6
2.忽略后五位
#include<stdio.h>#include<stdlib.h> int main(){ int k; scanf("%1d%*5d",&k);printf("%d",k); return 0; }
输入了123456后,输出结果为1
当scanf正确读入时,返回值是和读取的变量数目相等的,也就是读取了几个数就返回多少,而当读取出错、读到文件末尾时,scanf函数会返回-1