计算字符串最后一个单词的长度,单词以空格隔开。

#include
#include
using namespace std ;
int main ()
{
    string s;
    while (getline(cin,s))
           {
               int k=0,flag=1;
               for (int i=s.length()-1;i>=0;--i)
               {
                  if (flag && s[i]==' ')
                  {
                      continue;
                  }
                   else if (s[i]!=' ')
                   {
                       flag=0;
                       k++; 
                   }
                   else 
                   {
                       break;
                   }
               }
               cout<            }
    return 0;
}
这道题最重要的就是要考虑全面的问题。1)一个输入字符串如何表示?2)如何对字符串最后的几个字符进行判断?(反序循环)3)还有就是字符串最后为空格的时候该如何处理?

基于此,当最后为空格的时候,首先要把最后的空格字符给去掉,这里用的是continue跳过;接着这里一个很有用的就是flag,在最开始过滤后面的空格的时候用flag==1和s[i]==' '同时满足作为条件。当把最后的过滤掉以后就是统计字符个数了,这个没有什么难度,但将flag设置为0。接着当统计到这个字符串在此出现空格时候,由于最开始的if语句是flag==1和s[i]==' '同时满足,此时由于flag的关系,显然不满足了,所以直接break,跳出大循环了,统计结束!这里要仔细理解flag的用法问题,把函数的执行顺序弄明白。

你可能感兴趣的:(计算字符串最后一个单词的长度,单词以空格隔开。)