最近烧饼接到了一个任务,要求统计一篇文章中出现的不同单词的个数。但是烧饼觉得这个任务太简单了,所以他把这个任务交给了你,你能帮助他吗?
Input
多组数据,每组一行,表示一篇文章。文章只由小写字母和空格构成。
遇到#时表示输入结束
Output
每组输入输出一个整数,单独成行,表示这篇文章里不同单词的总数。
Sample Input
you are my friend
Sample Output
4
今天不知道怎么回事,这么简单的题都敲不出来
留下代码警醒自己:
#include<cstdio>
#include<algorithm>
#include<iostream>
#include<string>
#include<cstring>
using namespace std;
string a;
int main(){
while(1){
char b[1000][100],c[100];
getline(cin,a);
if(a[0]=='#')break;
int len=a.size(),g=0,n=0,vis=1;
a[len]=' ';
for(int i=0;i<=len;i++){
if(a[i]!=' '){
int m=0;
g=i;c[m++]=a[g];
for(i++;i<=len;i++){
if(a[i]==' ')break;
c[m++]=a[i];
}
c[m]='\0';
for(int j=0;j<n;j++){
if(strcmp(b[j],c)==0)vis=0;
}
if(vis){
strcpy(b[n++],c);
}
vis=1;
}
}
printf("%d\n",n);
}
}