计蒜课题库——最后一个单词的长度 【字符串处理】

题目:

给定由大写,小写字母和空格组成的字符串,返回 最后 一个单词的长度。

如果输入中不存在单词,返回 00

注意:

“单词”是指不包含空格符号的字符串

例如:

对于字符串"hello World"(不带引号), 那么返回的结果是 55

对于字符串"abc abc "(不带引号),那么返回的结果就是 33

输入格式

输入仅一行,为字符串 ss(长度不超过 1000010000)。

输出格式

输出 ss 中最后一个单词的长度。

样例输入1

Today is a nice day

样例输出1

3

样例输入2

The quick brown fox jumps over the lazy dog   

样例输出2

3

用到的知识点:1、读取一行包含空格的字符串 2、逐位判断字符串

分析:读取一行包含空格的字符串需要getline(cin,s)函数. 首先判断字符串中有没有大小写字母,没有的话输出0,有的话从字符串末尾读起,(坑点:有的字符串末尾是空格),遇到字母开始计数,直到再遇到空格停止计数。

#include<iostream>
#include<cstring>
using namespace std;
int main()
{
	string s;
	int num=0,flag=0;
	getline(cin,s);
	for(int j=0;j<s.length();j++)
	{
		if((s[j]>64&&s[j]<91)||(s[j]>96&&s[j]<123))
		{
			flag=1;
			break;
		}
	} 
	if(flag==0)
	{
		cout<<0;
		return 0;
	}
	else
	{
	
	int i=0;
	for( i=s.length()-1;s[i]==' ';i--)
	{
	}
		for(;s[i]!=' ';i--)
	{
		num++;
	}
	-
	cout<<num<<endl;
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/hwj729748198/article/details/79825379