字符串之单词统计

Problem H: C语言实验——单词统计

Description

从键盘输入一行字符,统计其中单词的个数,各单词以空格分隔,且空格数可以是多个。

Input

输入只有一行句子。仅有空格和英文字母构成。

Output

单词的个数。

Sample Input

stable marriage problem Consists     of Matchingmembers

Sample Output

7


#include <iostream>

#include <stdio.h>

#include <cstring>

using namespace std;

int main()

{

   int n,i,j;

   char str[1000];                

       gets(str);                   

       n=strlen(str);               

       j=0;

       for(i=0;i<=n-1;i++)            

       {if(str[i-1]==''&&str[i]!=' ') 

       j++;}

       cout<<j+1;                      

   return 0;

}

       统计单词的个数,其实考察的就是如何用程序语言描述符合单词的条件,对于一个长的字符串来说,单词就是该字符不是空格,无论该字符后面有什么,但前面一定是空格,这里,我们不考虑首行缩进的情况(如有需要,可自行修改);

       对于输入的字符串(gets(str);),依旧先求出其长度(n=strlen(str);),然后从第一个字符开始循环(for(i=0;i<=n-1;i++)),如果该字符不是空格并且前面的字符时空格(if(str[i-1]==' '&&str[i]!=' ')),则该字符是单词的第一个字母,统计计数加一(j++;)

       因为默认不考虑首行缩进的情况,所以第一个单词不符合统计要求,输出结果要考虑加一(cout<<j+1;)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章