输入
有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母,大写字母和空格组成,没有标点符号,遇到#时表示输入结束。
输出
每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。
样例输入
you are my friend
样例输出
4
/-------------------------------------------------------------------------------------------------------------------/
统计不同单词的个数就是要把所有单词分别处理成字符串,然后相互比较计数,每句话有多个单词,所以我们需要开一个二维字符数组,W [A ][B ] ,每一行存一个字符串,就可以在不定义多个字符数组的情况下,存储多个字符数组,在这里我们要考虑定义二维数组的问题,不能越界,越界问题我会在其他博客中特别说明,这里先不多说。
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
int main()
{
int l,i,j,k,a,b;
char s[10000],w[100][100]; // 一维数组接受整句话,二维数组把单词分开
while(gets(s))
{
if(s[0]=='#') //当接受为‘#’时结束
break;
a=0,b=0;
k=0;
l=strlen(s);
for(i=0; i<l;)
{
if(s[i]==' ')
{
i++;
}
else
{
while(s[i]!='\0'&&s[i]!=' ') //这里要在下面特殊说明!!!
{
w[a][b++]=s[i++];
}
a++;
b=0;
}
}
int flag=0;
for(i=0; i<a; i++)
{
flag=0;
for(j=0; j<i; j++)
{
if(strcmp(w[i],w[j])==0)
{
flag++;
}
}
if(flag==0)
k++;
}
printf("%d\n",k);
memset(s,'\0',sizeof(s)); //这里清空两个字符数组,从而不影响下次循环使用。
memset(w,'\0',sizeof(w));
}
return 0;
}
看到这里一定要注意,可能有人会疑惑,上面的IF中已经把空格的情况包含了,为什么这里还要判断是否为空格,大家可以想一下,当s[i]不是空格的时候,进入else,进入while,因为while中有i++,while会一直判断s[i]并且向后运行,如果这里不加判断是否为空格,那么在后面的s[i]中如果有空格的话也会存给w[a][b],所以这里一旦为空格,就退出循环,进行下面的步骤然后回到上面的IF判断,这时i值没有变,s[i]还是一个空格,到IF这里就会跳到i++了。