C++ 实现输入含空格的字符串
1、scanf函数(包含头文件#include <stdio.h>)
scanf函数一般格式为scanf(“%s”,st),但scanf默认回车和空格是输入不同组之间的间隔和结束符号,所以输入带空格,tab或者回车的字符串是不可以的。
解决方法如下:
1. 利用格式符“%[]”它的作用为扫描字符集合。
Scanf(“%[^c]”,str); 其中“c”是一个具体的字符常量(包括控制字符)。
当输入字符串时,字符“c”将被当作当前输入的结束符。
利用此格式符就可以由编程者自己指定一个输入结束符。
例如:
scanf("%[a-z A-Z0-9]",str)表示只匹配输入是大小写字母和数字,遇到非数字和字母时输入结束。
例如:
int main() { char st[50]; scanf("%[^\n]",st);// \n作为字符串输入的结束符 printf("%s",st); return 0; }
2. cin(包含头文件#include <iostream>)
cin是C++中最常用的输入语句,当遇到空格或者回车键即停止。无法解决。
3. gets()
可以无限读取,以回车结束读取,C语言中的函数,在C++中运行会产生bug。在C11标准中已被正式删除,建议不要用!!!
4. getline()(包含头文件#include <string>)
若定义变量为string类型,注意不是字符型数组。则要考虑getline()函数。
用法如下:
int main() { string st; getline(cin,st); cout<<st<<endl; return0; }
5.cin.get (char *str, int maxnum)
cin.get()函数可以接收空格,遇回车结束输入。
int main() { char st[50]; cin.get(st,50); cout<<a<<endl;// 输出也可以用printf("%s",st); return0; }
6.cin.getline (char *str, int maxnum)(包含头文件#include <string>)
cin.getline()函数可以同cin.get()函数类似,也可接收空格,遇回车结束输入。
int main() { char st[50]; cin.getline(a,50); cout<<a<<endl; // 输出也可以用printf("%s",st); return0; }
7. 字符串类型转换为字符数组
(a)c_str() char p[50]; string str="I Love Ningbo!"; strcpy(p,str.c_str()); printf("%s",p); (b)data() char p[50]; string str="I Love Ningbo!"; strcpy(p,str.data()); printf("%s",p);
补充知识:c++ cin输入空格
直接添加一行代码:
cin >> noskipws;
实例:
#include<iostream> using namespace std; int main() { cin >> noskipws;//设置cin读取空白符; char c; size_t acount =0, ecount =0, icount =0, ocount =0, ucount = 0,scount = 0; while (cin >> c) { if (c == 'a')++acount; if (c == 'e')++ecount; if (c == 'i')++icount; if (c == 'o')++ocount; if (c == 'u')++ucount; if (c == ' ')++scount; } cout << "a: " << acount << endl; cout << "e: " << ecount << endl; cout << "i: " << icount << endl; cout << "o: " << ocount << endl; cout << "u: " << ucount << endl; cout << "space: " << scount << endl; return 0; }
***运行结果:***
以上这篇C++ 实现输入含空格的字符串就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
C++使用MySQL-Connector/C++连接MySQL出现LNK2019错误的解决方法
这篇文章主要介绍了C++使用MySQL-Connector/C++连接MySQL出现LNK2019错误的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-03-03
最新评论