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;)!