/*单词数
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 29812 Accepted Submission(s): 7175
Problem Description
lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。
下面你的任务是帮助xiaoou333解决这个问题。
Input
有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。
Output
每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。
Sample Input
you are my friend
#
Sample Output
4
Author
Lily
Source
浙江工业大学网络选拔赛
Recommend
linle
*/
#include<stdio.h>
#include<string.h>
char s[5000][102];
int main()
{
int i, j, k, n, m;
char s1[10000];
while(gets(s1) != NULL)
{
if(strcmp(s1, "#") == 0)
break;
m = 0;
j = strlen(s1);
for(i = 0; i < j; i++)//划分单词 并 保存
{
if(s1[i] != ' ')
{
for(k = i; k < j; k++)
{
if(s1[k] != ' ')
s[m][k-i] = s1[k];
else
break;
}
s[m++][k-i] = '\0';
i = k;
}
}
n = m;
for(i = 0; i < m; i++)//去掉重复单词
{
if(s[i][0] != '\0')
for(j = i+1; j < k; j++)
{
if(strcmp(s[j], s[i]) == 0)
{
n--;
s[j][0] = '\0';
}
}
}
printf("%d\n", n);
}
return 0;
}
题意:给出一行字符串,要求输出串中不同种类的单词数。
思路:这里假设每个单词的长度不会大于100, 题目给出说明只包含空格和小写字母,所以可以以空格为分隔符将单词分离出来, 并保存到另一个数组里,记录个数,接着便是判断重复的个数,遇到一个便将长度减一。得出答案。