C语言用如何用scanf输入带有空格的字符串

Python015

C语言用如何用scanf输入带有空格的字符串,第1张

要输入带空格字符串,要用到一个格式字符:%[] -->一个字符集。

“%[]”的作用是扫描字符集合:

例如:scanf(“%[^\n]”,str)

具体作用是:如果输入的字符属于方括号内字符串中某个字符,那么就提取该字符;如果一经发现不属于就结束提取。该方法会自动加上一个'\0'到已经提取的字符后面。

#include <stdio.h>

int main()

{

char str[81]

printf("Please input a string:\n")

scanf("%[^\n]",&str)

printf("The string is:\n%s\n",str)

return 0

}

扩展资料:

字符串函数应用:

1. 连接运算 concat(s1,s2,s3…sn) 相当于s1+s2+s3+…+sn。

例:concat(‘11’,'aa’)='11aa’。

2. 求子串。 Copy(s,I,I) 从字符串s中截取第I个字符开始后的长度为l的子串。

例:copy(‘abdag’,2,3)=’bda’。

3. 删除子串。过程 Delete(s,I,l) 从字符串s中删除第I个字符开始后的长度为l的子串。

例:s:=’abcde’delete(s,2,3)结果s:=’ae’。

4. 插入子串。 过程Insert(s1,s2,I) 把s1插入到s2的第I个位置。

例:s:=abcinsert(‘12’,s,2)结果s:=’a12bc’。

5. 求字符串长度 length(s) 例:length(‘12abc’)=5。

在ASP中 求字符串长度用 len(s)例: len("abc12")=5。

参考资料:

百度百科-扫描集

scanf("%c",&answer) 与 scanf(" %c",&answer),后者只是在%前多了个空格,似乎没有什么区别,但使用起来区别是很大的。

scanf()作单字符输入时规定只接收一个字符,但它却把回车符也作为字符对待的。这就造成程序中只有一个输入字符的scanf()语句时,问题还不大,但如果后面还跟着第二个scanf()字符输入语句,这个scanf()就把前面输入的回车符当作输入字符了。这就在输入逻辑上造成了混乱,达不到人们预期的愿望。

有了这个空格,这个空格就相当于要求输入一个空格,刚好把刚才的'\n'接收掉。之所以' '能接收'\n',是因为"%c...."中的空格是广义的,对‘\n'、'\t'都有效。而且实践证明,这个空格放在%c后面也不能达到目的。应当说,这也是比较巧妙的应用!

%c前面的空格就是用来屏蔽空白符的,

首先必须要知道C语言 scanf() 函数的特性,以及scanf()与缓冲区、标准输入流之间的联系。在此之前,先介绍两个专业术语。

1.缓冲区

缓冲区是一块存放临时输入数据的内存,我们在键盘上输入数据之所以不会马上显示,就是因为数据存放在了缓冲区,在上面例子中,当我们按下回车键后,缓冲区的数据会传送到标准输入流。

2.标准输入流

标准输入流(stdin)是文件指针,scanf()就是从标准输入流或许数据。

以上面代码为例,当执行到scanf()时,

电脑开始执行以下操作:

开始等待用户输入

2.当我们输入数据,在按下回车键前会把数据储存在缓冲区,按下回车键后,会把数据以及换行符(\n)一起传送到标准输入流(stdin)中,

scanf()就是从标准输入流中或许数据,上面第一个scanf()要读入一个整数,它从标准输入流中查找,跳过空白符(空格、换行符、制表符)

3.如果遇到数字,则开始读入,直到遇到非数字的字符结束,最后计算读取到的数值,储存到相关变量中。

使用scanf注意事项

1.参数的个数一定要对应

2.输入的数据类型一定要和所需要的数据类型一致

3.每次调用完scanf后,记得调用一个getchar()函数

扩展资料

1.函数 scanf() 是从标准输入流stdio (标准输入设备,一般指向键盘)中读内容的通用子程序,可以说明的格式读入多个字符,并保存在对应地址的变量中。

2.函数的第一个参数是格式字符串,它指定了输入的格式,并按照格式说明符解析输入对应位置的信息并存储于可变参数列表中对应的指针所指位置。

每一个指针要求非空,并且与字符串中的格式符一一顺次对应。

参考资料

网页链接