scanf的用法,c语言中的scanf 函数的用法
scanf的用法,c语言中的scanf 函数的用法详细介绍
本文目录一览: scanf函数的用法
用法如下:
scanf()是C语言中的一个输出函数。与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include
。
scanf()函数的指定输入格式有很多种,下面是一些比较常用的格式:
%d:读入可选有符号的十进制整数。
%u:读入无符号符号十进制整数。
%a,e,f,g,A,E,F,G: 读入可选有符号浮点数,输入格式应该像strtod函数识别的字符序列一样。
%o:读入可选有符号八进制整数。
%s:读入一个的字符序列,后面会加上空字节,遇到空白字符(\t \r \n 空格等)完成读取。
使用格式:
scanf()是C语言中的一个输入函数。与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include
。
(在有一些实现中,printf函数与scanf函数在使用时可以不使用预编译命令#include
。)它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。
c语言中的scanf 函数的用法
1、空白符问题
#include
main()
{
int a;
printf("input the data ");
scanf("%d ",&a);//这里多了一个回车符
printf("%d",a);
return 0;
}
2、回车符也占位。
#include
main()
{
int n = 5;
char c[n];
for(int i = 0; i < n; i++)
c[i] = scanf("%c",&c[i]);
printf(c);
return 0;
}
3、scanf()函数的参数输入类型不匹配问题
#include
main()
{
int a=123;
char c='t';
printf("input ");
scanf("%d%c",&a,&c);
scanf("%d%c",&a,&c);
scanf("%d%c",&a,&c);
printf("%d %c ",a,c);
return 0;
}
扩展资料:
scanf函数用%s读取一个字符串时,其实它只能读取一个单词,因为遇到空格时,它会认为输入已结束。因此一般使用fgets来读取一个字符串。如果想用scanf函数读取带有空格的字符串时,需要使用参数%[ ]来完成,它的意思是读入一个字符集合。
[ ]是个集合的标志,%[ ]特指读入此集合所限定的那些字符,比如%[A-Z]是输入大写字母,一旦遇到不在此集合的字符便停止。如果集合的第一个字符是“^”,这说明读取不在"^"后面集合的字符,既遇到"^"后面集合的字符便停止(这就是scanf函数里的正则表达式应用)。
scanf是C语言中的一个输入函数,与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include 。(在有一些实现中,printf函数与scanf函数在使用时可以不使用预编译命令#include 。)它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。scanf函数返回成功读入的数据项数,读入数据时遇到了“文件结束”则返回EOF。
输出的值只是空格前面的字符是因为scanf函数的输入格式错误,输入参数的变量前需要加&。
scanf("%s",s);改为scanf("%s",&s);
scanf的用法是:scanf("格式控制字符串",输入参数一,输入参数二);
格式控制字符串包含:格式控制说明,普通字符。
1、格式控制字符串表示输入的格式,(int型用%d,float用%f,double型用%lf)
2、普通字符:在输出数据的时候,按照原样输出的字符,如:"fahr=%d,celsius=%d\n"中的fahr=,celsius=。
3、输入的参数是变量的地址,所以要在变量前面加&。
扩展资料
调用scanf()函数输入数据,变量名x前面要加&,%lf中的l是long的首字母,scanf函数的输入参数必须和格式控制字符串中的格式控制说明相对应,并且它们的类型,个数和位置要一一对应。
如果scanf中%d是连着写的如“%d%d%d”,在输入数据时,数据之间不可以用逗号分隔,只能用空白字符(空格或tab键或者回车键)分隔——“2 (空格)3(tab) 4” 或 “2(tab)3(回车)4”等。若是“%d,%d,%d”,则在输入数据时需要加“,”,如“2,3,4”。
参考资料来源:百度百科——scanf
输出的值只是空格前面的字符是因为scanf函数的输入格式错误,输入参数的变量前需要加&。
scanf("%s",s);改为scanf("%s",&s);
scanf的用法是:scanf("格式控制字符串",输入参数一,输入参数二);
格式控制字符串包含:格式控制说明,普通字符。
1、格式控制字符串表示输入的格式,(int型用%d,float用%f,double型用%lf)
2、普通字符:在输出数据的时候,按照原样输出的字符,如:"fahr=%d,celsius=%d\n"中的fahr=,celsius=。
3、输入的参数是变量的地址,所以要在变量前面加&。
扩展资料
“输出控制符”和“输出参数”无论在“顺序上”还是在“个数上”一定要一一对应。这句话同样对 scanf 有效,即“输入控制符”和“输入参数”无论在“顺序上”还是在“个数上”一定要一一对应。比如:
# include
int main(void)
{
char ch;
int i;
scanf("%c%d", &ch);
printf("ch = %c, i = %d\n", ch, i);
return 0;
}
参考资料:百度百科 - scanf
1、用法:int scanf(char *format[,argument,...]);
scanf()函数是通用终端格式化输入函数,它从标准输入设备(键盘) 读取输入的信息。可以读入任何固有类型的数据并自动把数值变换成适当的机内格式。
2、其调用格式为:
scanf("
",
);
scanf()函数返回成功赋值的数据项数,出错时则返回EOF。
3、scanf()函数的控制串的使用:
#include "stdio.h"
int main(void)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
printf("%d,%d,%d/n",a,b,c);
return 0;
}
扩展资料:
scanf 函数使用中的注意事项:
(1)在高版本的 Visual Studio 编译器中,scanf 被认为是不安全的,被弃用,应当使用scanf_s代替 scanf。
(2) 对于字符串数组或字符串指针变量,由于数组名可以转换为数组和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上"&"操作符。
(3) 可以在格式化字符串中的"%"各格式化规定符之间加入一个整数,表示任何读操作中的最大位数。
(4) scanf函数中没有类似printf的精度控制。
如: scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数为2位的实数。
参考资料来源:百度百科—scanf函数
scanf 函数最主要的用法是:
scanf("输入控制符", 输入参数);
功能:将从键盘输入的字符转化为“输入控制符”所规定格式的数据,然后存入以输入参数的值为地址的变量中。
用scanf()函数以%s格式读入的数据不能含有空白符时,所有空白符都被当做数据结束的标志。所以题中函数输出的值只有空格前面的部分。
如果想要输出包括空格在内的所有数据,可以使用gets()函数读入数据。gets()函数的功能是读取字符串,并存放在指定的字符数组中,遇到换行符或文件结束标志时结束读入。换行符不作为读取串的内容,读取的换行符被转换为字符串结束标志'\0'。
扩展资料:
使用scanf()函数需要注意的问题:
1.对于字符串数组或字符串指针变量,由于数组名可以转换为数组和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上"&"操作符。
2.可以在格式化字符串中的"%"各格式化规定符之间加入一个整数,表示任何读操作中的最大位数。
3.scanf函数中没有类似printf的精度控制。
如:scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数为2位的实数。
4.scanf中要求给出变量地址,如给出变量名则会出错
如:scanf("%d",a);是非法的,应改为scanf("%d",&a);才是合法的。
5.在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔,则可用空格,TAB或回车作间隔。
C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。
6.在输入字符数据(%c)时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
参考资料:
百度百科-scanf()函数
百度百科-gets()函数
地址表>
格式化字符串>
你需要知道的scanf函数用法
这一节,我们就来介绍与printf相反的scanf函数。
printf函数将二进制表示的整数、浮点数、字符、字符串等按照转换规范转换成字符,并打印在控制台上。与之相反,scanf将键盘输入的字符串根据转换规范,转换成二进制表示的整数、浮点数、字符或字符串等。
运行程序后,在键盘输入:“1 2 3 4 5.6 7.8”。scanf函数,将字符串"1 2 3 4 5.6 7.8",根据转换规范,分别转换为各类二进制数据,并存储到变量中。
printf函数将这些变量,按照转换规范,再转换为字符串,输出到控制台。
1. scanf函数的使用公式
scanf是一个变参函数。
scanf的第一个参数是字符串。
scanf的第一个参数内容为匹配字符以及转换规范。
scanf的后续参数,是转换完成后,数据的存放位置。
转换规范的写法与数量,需要与后续的参数类型和数量对应。
1.1 scanf是一个变参函数
和printf一样,scanf也是一个变参函数。之前我们也说了,变参函数中参数的数量和类型不确定。
1.2 scanf的第一参数是字符串
1.3 scanf的第一个参数为匹配字符以及转换规范。
请注意:输入时,需要按照第一个字符串的形式进行输入,否则无法得到正确结果。
例1: scanf第一个字符串为"%hhd %hd %d %ld %f %lf",每个转换规范使用空格分割。那么输入时需要用空格进行分割,形如1 2 3 4 5.6 7.8。
例2: scanf第一个字符串为"%hhd,%hd,%d,%ld,%f,%lf",每个转换规范使用,分割。那么输入时需要用逗号进行分割,形如1,2,3,4,5.6,7.8。
例3: scanf第一个字符串为"%hhd+%hd-%dx%ld/%f\~%lf",转换规范使用+-x/~分割。那么需要像这样输入1+2-3x4/5.6~7.8。
总而言之,scanf会将输入的字符串与第一个参数进行匹配,从而找到需要转换的部分。 若字符串匹配失败,将无法得到正确的转换结果。
1.4 scanf的后续参数,是转换完成后,数据的存放位置。
scanf将输入的字符串按照对应的转换规范进行转换,转换完成后的二进制,将依次存放到后续参数所输入的变量地址当中。暂时这里不讨论什么是变量的地址,请记住两个规则:
如果scanf将转换后的二进制存储到基本变量当中,请在变量名前加&。
如果scanf将字符串存储到字符数组中,字符数组名不用加&。
1.5 转换规范的写法与数量,需要与后续的参数类型和数量对应。
2. scanf函数具体做了什么
2.1 将输入字符串与第一个参数进行匹配
首先,scanf函数读取到输入的字符串。 接着,scanf会将这个输入字符串与第一个参数的字符串进行匹配,找到输入字符串中的子串与转换规范的一一对应关系。
子串"1"对应转换规范"%hhd" 子串"2"对应转换规范"%hd" 子串"3"对应转换规范"%d" 子串"4"对应转换规范"%ld" 子串"5.6"对应转换规范"%f" 子串"7.8"对应转换规范"%lf"
2.2 根据转换规范将字符转换为二进制
子串与转换规范匹配好之后就开始转换环节。scanf将根据子串对应的转换规范,使用不同的转换方式,将子串转换为二进制。
不同转换规范代表的转换方式如下表:
根据上表,对照我们的例子中的转换方式如下。
子串"1"对应转换规范"%hhd",将转换为char类型的二进制表示,1字节。
子串"2"对应转换规范"%hd",将转换为short类型的二进制表示,2字节。
子串"3"对应转换规范"%d",将转换为int类型的二进制表示,4字节。
子串"4"对应转换规范"%ld",将转换为long类型的二进制表示,4字节。
子串"5.6"对应转换规范"%f",将转换为float类型的二进制表示,4字节。
子串"7.8"对应转换规范"%lf",将转换为double类型的二进制表示,8字节。
2.3 将转换后的二进制放入变量
得到转换后的二进制后,将这些二进制根据顺序,依次放入变量当中。
由于我们使用了对应类型的变量来接收转换结果,所以长度和类型均可以保证一致。
3. 几类错误示范
3.1 长度正确但类型错误
我们输入了字符串"123.45",该字符串被转换规范"%lf"匹配。
接下来,字符串"123.456"将被转换为double类型的二进制表示,8个字节。
最后,这8个字节被送给了long long类型的变量ll。
现在变量ll是一个装有double类型二进制的整型了。
我们使用%d来打印ll肯定出现了错误的结果。
那我们使用%f来打印呢?%f将取8个字节的二进制,并且按照double类型二进制规则进行转换。结果就得到了正确的结果。
3.2 输入字符串数值大于转换类型取值范围
我们输入了字符串"2147483467",该字符串被转换规范"%hd"匹配。
接下来,字符串"2147483467"将被转换为short类型的二进制表示,2个字节。
而short类型的取值范围为-32767~32768,2147483467无法用short装下。
所以,无法得出正确的结果。
3.3 变量放不下转换结果
我们输入了字符串"2147483467",该字符串被转换规范"%d"匹配。
接下来,字符串"2147483467"将被转换为int类型的二进制表示,4个字节。
最后,转换后的4个字节的数据被short类型的变量s接收,丢失了2个字节。
所以,无法得出正确的结果。
3.4 如何避免错误
我们输入了字符串"2147483467",该字符串被转换规范"%d"匹配。
接下来,字符串"2147483467"将被转换为int类型的二进制表示,4个字节。
最后,转换后的4个字节的数据被int类型的变量n接收。
正确结果。
使用scanf的时候请注意,输入字符串的数值与转换规范和接收转换结果的变量类型必须匹配才能得到正确结果。
4. 字符和字符串
4.1 输入字符
我们来试试看输入一个字符吧。
我们输入了字符串"A",该字符串被转换规范"%c"匹配。
接下来,字符串"A"将被转换为char类型的二进制表示(其十进制为65),1个字节。
最后,转换后的1个字节的数据被char类型的变量c接收。
当我们用%d打印c时,输出了数值65。而用%c打印时,输出了字符c。
如果要给char类型输入数值,请使用转换规范hhd。若还是使用转换规范c。会将第一个字符的ASCII码装入变量。
4.2 输入字符串
c语言中没有字符串变量,字符串被存储在字符数组当中。
由于这里是将输入的字符串存储到字符数组中,后面的参数str不加&。
目前我们还没有讨论过数组,暂时不继续展开这一部分内容。
5. VS无法使用scanf函数
如果你使用的是较新版本的Visual Studio,scanf这类函数会被认为是不安全的,编译器会抛出C4996错误,并建议你使用别的安全函数替代。
但是,目前我们并不想引入并讨论这一类安全函数。请将_CRT_SECURE_NO_WARNINGS加入预定义字符串,屏蔽不安全函数错误。
添加步骤方式如下:
解决方案下,工程点右键,进入属性。
展开C/C++,选择预处理器。
点击预处理器定义【编辑】。
将_CRT_SECURE_NO_WARNINGS加入预处理定义。
6. scanf与printf的不同
printf的后续参数不要加&,而scanf由于需要一个地址,所以对于基本变量需要加&,数组则不需要。
printf的参数由于比int小的变量会升级为int,float会升级为double。所以,转换规范d可以用于char,short,int。转换规范f可以用于float和double。但是scanf是直接把转换结果送到接收变量中,必须严格使用转换规范。
c语言scanf的用法
用法:int scanf(char*format,[argument,...]);
scanf()函数是通用终端格式化输入函数,它从标准输入设备(键盘)读取输入的信息。可以读入任何固有类型的数据并自动把数值变换成适当的机内格式。
其调用格式为:scanf(“
”,
);
scanf()函数返回成功赋值的数据项数,出错时则返回EOF;
其控制串由三类字符构成:
1、格式化说明符
2、空白符
3、非空白符
格式化说明符
附加格式说明字符表:
空白字符
空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符,空白符可以是space,tab,newline等等,直到第一个非空白符出现为止。
非空白字符
一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。
扩展资料:实例详解:
#include"stdio.h"
int main(void)
{
int a,b,c;
scanf("%d,%d,%d",&a,&b,&c);
printf("%d,%d,%d/n",a,b,c);
return 0;
}
运行时按如下方式输入三个值:
3□4□5↙(输入a,b,c的值)
3,4,5(printf输出的a,b,c的值)
(1)&a、&b、&c中的&是地址运算符,分别获得这三个变量的内存地址。
(2)“%d%d%d”是按十进值格式输入三个数值。输入时,在两个数据之间可以用一个或多个空格、tab键、回车键分隔。
以下是合法输入方式:
①3□□4□□□□5↙
②3↙
4□5↙
③3(tab键)4↙
5↙
例2
#include"stdio.h"
int main(void)
{
int a,b,c;
scanf("%d,%d,%d",&a,&b,&c);
printf("%d,%d,%d/n",a,b,c);
return 0;
}
运行时按如下方式输入三个值:
3,4,5↙(输入a,b,c的值)
或者
3,□4,□5↙(输入a,b,c的值)
3,□□□4,□5↙(输入a,b,c的值)
……
都是合法的,但是”,”一定要跟在数字后面,如:
3□,4,□5↙就非法了,程序出错。(解决方法与原因后面讲)
再如:
1、sacnf()中的变量必须使用地址
int a,b;
scanf("%d%d",a,b);//错误
scanf("%d%d",&a,&b);
2、scanf()的格式控制串可以使用其它非空白字符,但在输入时必须输入这些字符。
例:
scanf("%d,%d",&a,&b);
输入:3,4↙(逗号与”%d,%d”中的逗号对应)
scanf("a=%d,b=%d",&a,&b);
输入:a=3,b=4↙(”a=”,”b=”,逗号与”%d,%d”中的”a=”,”b=”及逗号对应)
3、在用”%c”输入时,空格和“转义字符”均作为有效字符。
例:
scanf("%c%c%c",&c1,&c2,&c3);
输入:a□b□c↙
结果:a→c1,□→c2,b→c3(其余被丢弃)
scanf()函数接收输入数据时,遇以下情况结束一个数据的输入:(不是结束该scanf()函数,scanf()函数仅在每一个数据域均有数据,并按回车后结束)。
①遇空格、“回车”、“跳格”键。
②遇宽度结束。
③遇非法输入。
地址表>
格式化字符串>
scanf函数的用法
D
123
后
c1==1,c2==2,c3==3,c4==10(回车)
之后c5=getchar();会把输入缓冲区的一个字符赋值给C5,所以c5=4
c6=getchar();由于输入缓冲区不为空,所以会自动取一个字符赋值给C6,所以c6=5
D
putchar(c1);输出1
putchar(c2);输出2
c5=getchar();输入4
c6=getchar();输入5
printf("%c%c\n",c5,c6);输出4 5
#include
void main()
{
char c1,c2,c3,c4,c5,c6;
scanf("%c%c%c%c",&c1,&c2,&c3,&c4);
c5=getchar();
c6=getchar();
putchar(c1);
putchar(c2);
printf("%c%c\n",c5,c6);
}
/*
作为一位编程人员,指出你所写的程序中的一个问题。在书写代码时,要在半角字符下书写。不要在全角字符下写,虽然调试时可以改正,但显得自己资历浅。
首先,了解下putchar,getchar表示的意思和作用。
putchar函数(字符输出函数)的作用是向终端输出一个字符。
一般格式为:
putchar(c)
getchar函数(字符输入函数)的作用是从终端(或系统隐含指定的输入设备)输入一个字符。
****getchar函数没有参数****
一般格式为:
getchar()
当你从键盘输入123回车时,回车符也算入了字符的范围,就是c4为回车符,由于c5和c6还各自等待接受
从键盘输入的一个字符。所以在输入123回车时不会直接输出12,一直等到接受了c5和c6就依次打印出1245
注意putchar只能向终端输出一个字符,getchar只能接受一个字符,
虽然第一次输入了123和回车符,但是:
putchar(c1);
putchar(c2);
只能输出12两个字符。
虽然第二次输出了45678和回车符,
但是:
c5=getchar();
c6=getchar();
只能接受45.
所以输出1245了。
*/
功 能: 执行格式化输入
用 法: int scanf(char *format[,argument,...]);
scanf()函数是通用终端格式化输入函数,它从标准输入设备(键盘) 读取输入的信息。可以读入任何固有类型的数据并自动把数值变换成适当的机内格式。
其调用格式为: scanf("
",
);
scanf()函数返回成功赋值的数据项数,出错时则返回EOF。
其控制串由三类字符构成:
1。格式化说明符;
2。空白符;
3。非空白符;
(A) 格式化说明符
格式字符 说明
%a 读入一个浮点值(仅C99有效)
%A 同上
%c 读入一个字符
%d 读入十进制整数
%i 读入十进制,八进制,十六进制整数
%o 读入八进制整数
%x 读入十六进制整数
%X 同上
%c 读入一个字符
%s 读入一个字符串
%f 读入一个浮点数
%F 同上
%e 同上
%E 同上
%g 同上
%G 同上
%p 读入一个指针
%u 读入一个无符号十进制整数
%n 至此已读入值的等价字符数
%[] 扫描字符集合
%% 读%符号
scanf()是C语言中的一个输入函数。
scanf函数的用法与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include
。(在有一些实现中,printf函数与scanf函数在使用时可以不使用预编译命令#include
。)它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。
扩展资料:
使用scanf函数的注意问题:
1、在高版本的 Visual Studio 编译器中,scanf 被认为是不安全的,被弃用,应当使用scanf_s代替 scanf。
2、对于字符串数组或字符串指针变量,由于数组名可以转换为数组和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上"&"操作符。
3、 可以在格式化字符串中的"%"各格式化规定符之间加入一个整数,表示任何读操作中的最大位数。
4、scanf函数中没有类似printf的精度控制。
如: scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数为2位的实数。
5、scanf中要求给出变量地址,如给出变量名则会出错
如 scanf("%d",a);是非法的,应改为scanf("%d",&a);才是合法的。
6、 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔,则可用空格,TAB或回车作间隔。
C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。
7、在输入字符数据(%c)时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
参考资料来源:百度百科-scanf (计算机语言函数)
地址表>
格式化字符串>
回车>
scanf和printf的区别及用法是什么?
区别:scanf是输入函数,用于从标准输入设备(一般是键盘)输入数据;而printf是输出函数,用于向标准输出设备(一般是显示器)输出数据。
scanf()与printf()是C标准库常用到的函数。而且两个函数都可以接受一定的格式来进行输入和输出。
在调用printf与scanf的时候一定要包含#include。
printf的用法是:
printf(“格式控制字符串”,输出参数一,输出参数二)。
格式控制字符串包含:格式控制说明,普通字符。
格式控制说明主要是按指定的格式输出数据,包含以%开头的格式控制字符,不同类型的数据采用不同的格式控制字符(int型用%d,float和double用%f)。
普通字符就是在输出数据的时候,按照原样输出的字符,如:"fahr=%d,celsius=%d\n"中的fahr=,celsius=这些。
scanf的用法是:
scanf(“格式控制字符串”,输入参数一,输入参数二)。
格式控制字符串包含:格式控制说明,普通字符。
格式控制字符串表示输入的格式,(int型用%d,float用%f,double型用%lf)。
普通字符:和上面谈到的printf的用法是一样的。
输入的参数是变量的地址,所以要在变量前面加&。
scanf 怎么用
scanf 函数原型
int scanf( const char *format, ... );
scanf()函数是格式化输入函数,它从标准输入设备(键盘) 读取输入的信息。
其调用格式为: scanf("
",
);
函数 scanf() 是从标准输入流 stdin 中读内容的通用子程序,可以读入全部固有类型的数据并自动转换成机内形式。
scanf的返回值
scanf()函数返回成功赋值的数据项数,读到文件末尾出错时则返回EOF。
如:
scanf("%d,%d", &a, &b);
如果a和b都被成功读入,那么scanf的返回值就是2
如果只有a被成功读入,返回值为1
如果a和b都未被成功读入,返回值为0
如果遇到错误或遇到end of file,返回值为EOF。
且返回值为int型.
例:使用scanf函数输入数据。
#include
int main()
{
int a,b,c;
printf("输入 a, b, c\n");
scanf("%d,%d,%d", &a, &b, &c);
printf("a = %d b = %d c = %d\n", a, b, c);
fflush(stdin);
return 0;
}
注意上面的scanf("%d,%d,%d",&a,&b,&c);中%d,%d,%d之间有逗号,在输入数据时也要加逗号,如果去掉逗号,输入时就不用逗号,而用空格,tab键或回车键将各个数据隔开
#include
int foo(void)
{
int num;
scanf("%d", &num);
return num;
}
scanf格式输入函数与printf函数一样,都被定义在头文件stdio.h里,因此在使用scanf函数时要加上#include
。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。函数作用:按照变量在内存的地址将变量值存进去。具体用法如下:
一般格式:scanf(格式控制,地址表列)
其中,格式控制:
%d:以带符号的十进制形式输出整数
%o:以八进制无符号形式输出整数
%x:以十六进制无符号形式输出整数
%u:以无符号十进制形式输出整数
%c:以字符形式输出,只输出一个字符
%s:输出字符串
%f:以小数形式输出单,双精度数,隐含输出六位小数
%e:以指数形式输出实数
%g:选用%f或%e格式中输出宽度较短的一种格式,不输出无意义的0
在格式控制的字母前面可以用几种常见的格式符的修饰符,作用如下:
L:用于长整型整数,可加在格式符d,o,x,u前面
M(代表一个正整数):数据最小宽度
N(代表一个正整数):对实数,表示输出n位小数;
对字符串,表示截取的字符个数
地址列表:是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址
举例:
用scanf函数输入数据。
#include
void main()
{
int a,b,c;
scanf(“%d%d%d”,&a,&b,&c);
printf(“%d,%d,%d\n”,a,b,c);
}
运行情况:3 4 5 (回车) (输入a,b,c的值)3,4,5 (输出a,b,c的值)
使用scanf函数时应注意的问题 :
(1)scanf函数中的“格式控制”后面应当是变量地址,而不应是变量名。
(2) 如果在“格式控制”字符串中除了格式说明以外还有其他字符,则在输入数据时在对应位置应输入与这些字符相同的字符。
(3) 在用“%c”格式输入字符时,空格字符和“转义字符”都作为有效字符输入。
(4) 在输入数据时,遇以下情况时认为该数据结束。
① 遇空格,或按“回车”或“跳格”(Tab)键;
② 按指定的宽度结束,如“%3d”,只取3列;
③ 遇非法输入。
地址表>
格式化字符串>
关于scanf的用法
scanf与printf函数一样,都被定义在头文件stdio.h里,因此在使用scanf函数时要加上#include
。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。
如int scanf(const char *format,...);
scanf()是C语言中的一个输入函数。与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include
。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。
函数返回值为int型。如果a和b都被成功读入,那么scanf的返回值就是2;
如果只有a被成功读入,返回值为1;
如果a和b都未被成功读入,返回值为0;
如果遇到错误或遇到end of file,返回值为EOF。
因为你这里用的是scanf所以输出缓寸里的数据不会马上输出,而是等你回车,结束输入之后一起输出,所以第一次输出本来该输出3,可是因为你没回车,被延迟了,但你回车之后会把输出缓存里的3和7一起输出!
具体如下:
1、记住一点,scanf认为遇到“非法输入”就结束。
2、scanf("%2d%f",&a,&b);中第一个格式控制字符2d的意思是读取2位,作为一个整数输入到给对应的变量a的地址中。输入876,当然只读取前2位87。这是2的作用,后面输入对于2来说,相当于非法输入。
3、对于%f,后面输入的是7 543.0,对于浮点型数据是不可能得到空格的,所以遇到空格,认为是非法输入,结束输入。所以b的值是6,即是6.000000。
4、scanf函数是C语言中的一个输入函数,与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include 。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中,其关键字最末一个字母f即为“格式”(format)之意。
我来说一下吧。
scanf("%d",&a);
b=a;
这样是没有问题的。
b=scanf("%d",&a);
看看下面:
int scanf( const char *format, ... ); 【定义格式】
scanf()函数返回成功赋值的数据项数,读到文件末尾出错时则返回EOF。
如:
scanf("%d,%d", &a, &b);
如果a和b都被成功读入,那么scanf的返回值就是2
如果只有a被成功读入,返回值为1
如果a和b都未被成功读入,返回值为0
如果遇到错误或遇到end of file,返回值为EOF。
scanf和printf的区别及用法是什么?
scanf与printf的区别及用法:
一、指代不同
1、printf:是格式化输出函数。
2、scanf:是C语言中的一个输入函数。
二、功能不同
1、printf:用于向标准输出设备按规定格式输出信息。
2、scanf:是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。
三、特点不同
1、printf:的调用格式为:printf("
<格式化字符串>", <参量表>)。printf()是c语言标准库函数,在stdio.h中定义。输出的字符串除了可以使用字母、数字、空格和一些数字符号以外,还可以使用一些转义字符表示特殊的含义。
2、scanf:scanf()是从标准输入流stdin(标准输入设备,一般指向键盘)中读内容的通用子程序,可以说明的格式读入多个字符,并保存在对应地址的变量中。
格式化字符串>",>