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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值