题目链接:传送门

Problem Description

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

 

Input

有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。

 

Output

每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。

 

Sample Input

you are my friend

#

 

Sample Output

4

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<map>
using namespace std;
char m[10000005];
int main()
{
    int a,b,d,e,f;
    while(gets(m))
    {
        if(m[0]=='#')
            break;
        a=strlen(m);
        map<string,int>s;
        s.clear();
        e=0;
        for(b=0;b<a;b++)
        {
            string n;
            while(m[b]!=' ')
            {
                if(b>=a)
                    break;
                n=n+m[b];
                b++;
            }
            if(s[n]==0)
            {
                e++;
                s[n]=1;
            }
        }
        string n;
        if(s[n]==1)
            e--;
        cout<<e<<endl;
    }
    return 0;
}