题目要求
给定由大写,小写字母和空格组成的字符串,返回最后一个单词的长度。
如果输入中不存在单词,返回 000。
注意:
“单词”是指不包含空格符号的字符串
例如:
对于字符串"hello World"(不带引号), 那么返回的结果是 5;
对于字符串"abc abc "(不带引号),那么返回的结果就是 3。
输入要求
输入仅一行,为字符串 sss(长度不超过 10000)。
输出要求
输入最后一个单词的长度
算法思想
我们考虑到string函数当中的size()和rfind()两个函数,通过size函数看到整个字符串的长度,通过rfind函数找到最后一个空格的数组下标,然后用整个字符串的长度减去最后一个空格的位置,那么这个就是最后一个单词的长度,但是这里要注意,数据当中出现了单词最后还带有空格的样例,我们在使用这两个函数之前,需要把单词后面的空格处理掉,不然rfind函数就找不到最后一个单词前面的空格
#include<iostream>
#include<cstdio>
#include<string>
using namespace std;
int main(){
string str;
getline(cin,str);
int lastnum2=str.size()-1;//总体的数组下标
int k=str.size()-1;
while(1){//去除字符串最后面的空格
if(str[k]!=(char)32){
break;
}else{
str[k]=NULL;
k--;
lastnum2--;
}
}
int lastnum1=str.rfind(" ");//找到最后查找的数组下标
if(lastnum1==-1)cout<<str.size();//没有空格的话直接就是字符串的长度
else cout<<lastnum2-lastnum1;//有空格的话就是字符串的长度减去最后一个空格的数组下标
return 0;
}