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;
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/80840.html