总结
大致思路就是用map把单词转化成数组的方式,在存下一个单词的时候 只需判断这个单词所对用的mp数组是否已经存在,如果不存在则令其为1,无论是否存在 最后都把字符串s重置。主要考察的就是map的用法和string的用法
lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。下面你的任务是帮助xiaoou333解决这个问题。
大致思路就是用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;
}