找不同单词的个数

总结
            大致思路就是用map把单词转化成数组的方式,在存下一个单词的时候 只需判断这个单词所对用的mp数组是否已经存在,如果不存在则令其为1,无论是否存在 最后都把字符串s重置。主要考察的就是map的用法和string的用法

lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。下面你的任务是帮助xiaoou333解决这个问题。

Input 有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。 Output 每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。 Sample Input
you are my friend
#
Sample Output
4
#include<stdio.h>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cmath>
#include<map>
using namespace std;
int main()
{
	string s;
	map<string,int>mp;
	char c;
	int num=0;
	while(c=getchar())
	{
		if(c>='a'&&c<='z'||c>='A'&&c<='Z')
		{
			s+=c;
		}
		if(c==' ')
		{
			if(mp[s]==0)
			{
				if(s.size()!=0)
				{
					mp[s]=1;
					num++;
				}
				
			}
			s="";
		}
		if(c=='\n')
		{
			if(mp[s]==0)
			{
				if(s.size()!=0)
				{
					mp[s]=1;
					num++;
				}
				
			}
			s="";
			cout<<num<<endl;
			mp.clear();
			num=0;
		}
		if(c=='#')
		{
			break;
		}
		
	}
	return 0;
}



猜你喜欢

转载自blog.csdn.net/henucm/article/details/80201036