今天在重温 C++ 的时候发现自己存在的一些问题,特此记录下来。

我们可以看一下下面这段代码:

#include <iostream>
#include <cstdio>
#include <string>
#include <cctype>
using namespace std;
int main(int argc, char const *argv[])
{
string s;
cin >> s;
int cnt[26]={0};//字母统计次数
for(int i = 0; i < s.length(); i++){
char c = s[i];
if(isalpha(c)){
cnt[toupper(c) - 'A'] ++;
}
}
for(int i = 0; i < 26; i++){
if(cnt[i] != 0){
cout << char(i + 'A') << ": " << cnt[i] <<endl;
}
}
return 0;
}

当我们输入字符串 Hello World! 时,结果会是多少呢?

apple@localhost  ~/Desktop/cpp_code  g++ run.cpp -o run.out -std=c++11 -O2
apple@localhost  ~/Desktop/cpp_code  ./run.out
Hello World!
E: 1
H: 1
L: 2
O: 1

上面这段代码并不能很好的统计字符串中每个英文字母在其中的出现频率,我苦思冥想了许久,才发现了一个曾经忽略过的一个问题,cin 标准输入字符串在遇到空格时候将会被截断,而我们需要对输入一个带空格的字符串进行特殊处理,而使用 getline 可以完美的解决该问题。getline(std::cin, std::string) 在输入回车符号时才会被截断,把上述代码的输入做一些调整就可以完美的解决问题。

ps: 这种方法是针对 string 类

#include <iostream>
#include <cstdio>
#include <string>
#include <cctype>
using namespace std;
int main(int argc, char const *argv[])
{
string s;
getline(cin, s);
int cnt[26]={0};//字母统计次数
for(int i = 0; i < s.length(); i++){
char c = s[i];
if(isalpha(c)){
cnt[toupper(c) - 'A'] ++;
}
}
for(int i = 0; i < 26; i++){
if(cnt[i] != 0){
cout << char(i + 'A') << ": " << cnt[i] <<endl;
}
}
return 0;
}

当我们再次输入字符串 Hello World! 时,结果又会是多少呢?

apple@localhost  ~/Desktop/cpp_code  g++ run.cpp -o run.out -std=c++11 -O2
apple@localhost  ~/Desktop/cpp_code  ./run.out
Hello World!
D: 1
E: 1
H: 1
L: 3
O: 2
R: 1
W: 1

这就很OK了!

除此之外,还有没有其他方法可以输入带空格的字符串呢?

答案是有的,以下我将所有可能出现的情况一一列举出来。

情景一:已知输入的字符串序列

针对这种情况,我们可以直接在定义的时候输入字符串序列即可,例如我们已知我们要输入的字符串序列为 Hello World! ,我们可以写出如下定义:

str = "Hello World!";

情景二:输入字符串序列未知,但是知道字符串序列的最大长度范围

方法一:

按照上述所给的 getline 函数,我们可以通过如下调用方法:

cin.getline(str, len);

第一个参数 str 用来存储输入行的数组名称,第二个参数是要读取的字符数。

方法二:

我们可以使用字符数组的方式去解决这个问题,这个时候我们自然会想到 get 方法,调用方式如下:

cin.get(str, len);

和方法一一样,两者都是读取一行输入,直至换行符,而两者的不同在于 getline 将换行符丢弃,而 get() 将换行符保留在输入序列里,于是我们会考虑如下改写方式:

while((c=cin.get())!='\n')

而若是采用 C 语言函数库中的办法,我们又应该如何去表示呢?

方法三:

C语言中输入一个字符串,我们首先想到的就是使用 scanf 函数,但 scanf 默认回车和空格是输入不同组之间的间隔和结束符号,所以输入带空格,tab或者回车的字符串是不可以的,我们可以利用格式符 “%[]” 。它的作用为扫描字符集合,调用方式如下:

scanf("%[^c]", str);

其中 “c” 是一个具体的字符常量(包括控制字符)。当输入字符串时,字符 “c” 将被当作当前输入的结束符。利用此格式符就可以由编程者自己指定一个输入结束符。

方法四:

C语言中还有一种输入字符串的方式,即使用 gets 函数。gets函数是以回车作为结束符,调用方式如下:

char str[length];
gets(str);

其中 length 是字符串序列最大的长度范围,是一个具体的数值。

情景三:输入字符串序列未知,且字符串序列的最大长度范围也未知

针对这种 string 类问题,这个时候我们只有采用 getline 函数去解决了,调用方式如下:

getline(cin, s);

C/C++ 中带空格字符串输入的一些小trick的更多相关文章

  1. [原创]C++带空格字符串的输入问题

    字符串一直是一个重点加难点,很多笔试面试都会涉及,带空格的字符串更是十分常见,现在对字符串的输入问题进行一下总结. C++用cin输入的时候会忽略空格以后的字符,比如 char a[100]; cin ...

  2. git bash中带空格的文件夹以及文件的处理

    空格用'\ '表示,输入的时候,是不需要单引号的 total 338drwxr-xr-x 9 Administ Administ 4096 Aug 24 23:53 HDTHelperdrwxr-xr ...

  3. find + xargs + cp 遇到文件名中带空格如何处理

    一,需求为查询文件名为ZRSH开头的时间为7月至今的所有文件并打包 1.首先想到的就是find + xargs + cp  格式.. find 2016073* -type f  -name *ZRS ...

  4. C# 调用cmd命令行路径中带空格问题

    今天打包winform程序,程序中本身有一处需要调用cmd.exe,打包安装在C:\Program Files目录下,然后调用cmd的地方,就弹出了C:\Program不是内部或外部命令,也不是可运行 ...

  5. java实现带空格字符串的倒序输出

    import org.junit.Test; public class StringtoChar { @Test public void main(){ String str ="hello ...

  6. C语言中的各种字符串输入方法

    C语言从stdin读取一行字符串的几种方法 gets gets函数的头文件是<stdio.h>,原型如下: char *gets(char *s); gets从stdin中读入一行内容到s ...

  7. GO语言学习笔记1-输入带空格的字符串

    最近开始学习GO语言,并做了一些编程练习.有道题要输入带空格的字符串,这在C/C++中很容易实现,但GO中好像并不那么容易.学过C/C++的可能都知道,在C中可以使用gets()函数,在C++可以使用 ...

  8. URL中的空格

    如果URL中带空格,在浏览器中可以显示,但是如果访问比如 UIImage 获取图片的时候就会出现BAD URL. 解决: NSString* urlText = @"70.84.58.40/ ...

  9. C\C++对于字符串输入处理

    1.scanf scanf以%s格式符读入字符串,会以空格为结束,也就是无法将空格读入.如果换成%c就可以读入,但是无法一次性读入一整行字符. 2.fgets 显然,fgets是一个读取带空格字符串的 ...

随机推荐

  1. Leetcode之深度优先搜索(DFS)专题-199. 二叉树的右视图(Binary Tree Right Side View)

    Leetcode之深度优先搜索(DFS)专题-199. 二叉树的右视图(Binary Tree Right Side View) 深度优先搜索的解题详细介绍,点击 给定一棵二叉树,想象自己站在它的右侧 ...

  2. Python中绘制场景热力图

    我们在做诸如人群密集度等可视化的时候,可能会考虑使用热力图,在Python中能很方便地绘制热力图. 下面以识别图片中的行人,并绘制热力图为例进行讲解. 步骤1:首先识别图像中的人,得到bounding ...

  3. SpringBoot 2 快速整合 | 统一异常处理

    统一异常处理相关注解介绍 @ControllerAdvice 声明在类上用于指定该类为控制增强器类,如果想声明返回的结果为 RESTFull 风格的数据,需要在声明 @ExceptionHandler ...

  4. Keras(六)Autoencoder 自编码 原理及实例 Save&reload 模型的保存和提取

    Autoencoder 自编码 压缩与解压 原来有时神经网络要接受大量的输入信息, 比如输入信息是高清图片时, 输入信息量可能达到上千万, 让神经网络直接从上千万个信息源中学习是一件很吃力的工作. 所 ...

  5. HTML(七)CSS

    一个实例 <!DOCTYPE html> 菜鸟教程(runoob.com) body { background-color:#d0e4fe; } h1 { color:orange; te ...

  6. c#搭建webapi项目

    一.添加WebApi项目     二.nuget下载WebApi所需的类库引用 install-package Microsoft.AspNet.WebApi install-package Micr ...

  7. P2766 最长不下降子序列问题 网络流

    link:https://www.luogu.org/problemnew/show/P2766 题意 给定正整数序列x1,...,xn . (1)计算其最长不下降子序列的长度s. (2)计算从给定的 ...

  8. Codeforces Round #465 &935C. Fifa and Fafa计算几何

    传送门 题意:在平面中,有一个圆,有一个点,问能在这个圆中围出最大的圆的圆心坐标和半径.要求这个最大圆不包含这个点. 思路:比较基础的计算几何,要分三种情况,第一种就是这个点在圆外的情况.第二种是点在 ...

  9. codeforces 633F The Chocolate Spree (树形dp)

    题目链接:http://codeforces.com/problemset/problem/633/F 题解:看起来很像是树形dp其实就是单纯的树上递归,就是挺难想到的. 显然要求最优解肯定是取最大的 ...

  10. hdu4565 So Easy!(矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4565 题解:(a+√b)^n=xn+yn*√b,(a-√b)^n=xn-yn*√b, (a+√b)^n ...