Hduoj2072 【水题】【字符串处理】

/*单词数
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, 题目给出说明只包含空格和小写字母,所以可以以空格为分隔符将单词分离出来, 并保存到另一个数组里,记录个数,接着便是判断重复的个数,遇到一个便将长度减一。得出答案。

你可能感兴趣的:(c)