1. 题目描述
题目链接:HJ1 字符串最后一个单词的长度
2. 解题思路
先找到字符串中最后一个空格的位置,空格之后的字符个数就是最后一个单词的长度。若字符串中不存在空格,则字符串的长度就是最后一个单词的长度。
该题的思路很简单,但该题真正的难点不是如何求得字符串中最后一个单词的长度,而是如何读取一个含有空格的字符串。
举个例子,当我们输入:ABSIB T
这个字符串的适合,遇到中间的空格时,编译器就会默认你这次的输入已经结束了,而后面的 T 是放到缓冲区的,拿不到。
因为操作符 >>
读取到空格便会停止,所以不能使用 >>
读取目标字符串,这时我们就需要用到 getline
函数了,该函数便可以读取含有空格的内容。
3. 代码实现
代码示例
#include <iostream>
using namespace std;
int main() {
string str;
getline(cin, str);
size_t pos = str.rfind(' ');
if (pos != string::npos) {
cout << str.size() - 1 - pos << endl;
}
else {
cout << str.size() << endl;
}
}