B4-统计单词
描述 本题所说的单词是一个由ASCII码构成不含有空格(包括退格键符)的串。给定一个字符串,统计其中单词的个数。输入 输入的第一行有一个整数T,表示下面有T行,T<10。
T行数据的每行上有一个字符串对应一种情形(不含有退格键符)。字符串中分隔单词的字符仅考虑空格(可能是连续的空格)。字符串的长度不超过65536字符。
输出 对于每一种情形,先输出“Case #:”(#为序号,从1起),空1格后输出该串中单词的个数。
样例输入1
2
This is a test.
BASIC FORTRAN Pascal C C++ Java
样例输出1
Case 1: 4
Case 2: 6
不用管重复的个数。很简单了。
但是有个地方卡了一下。
判断时注意是c[i]!=’\0’不是’\n’
#include<bits/stdc++.h>
using namespace std;
const int maxn=65536;
int main()
{
int t,cnt;
cin>>t;
int i,m=1;
getchar();
while(t--)
{
cnt=0;
i=0;
char c[maxn];
gets(c);
while(c[i]!='\0')
{
if(c[i]!=' '&&c[i]!='\0')
{
if(c[i+1]==' '||c[i+1]=='\0')
{
cnt++;
}
}
i++;
}
cout<<"Case "<<m++<<": "<<cnt<<endl;
}
return 0;
}