单词数
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 20143 Accepted Submission(s): 4901
Problem Description
lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。下面你的任务是帮助xiaoou333解决这个问题。
Input
有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。
Output
每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。
Sample Input
you are my friend #
Sample Output
4
参考代码
#include<stdio.h> #include<string.h> int main() { int i,j,k,len,n,m; char a[30000],b[2]="#",c[1000][20]; while(gets(a)) { if(strcmp(a,b)==0) break; k=j=m=n=0; len=strlen(a); for(i=0;i<len;i++) { if(a[i]>='a'&&a[i]<='z') { c[j][k]=a[i]; k++; } else if(k>0) { c[j][k]='\0'; j++;k=0; } if(i==len-1&&a[len-1]>='a'&&a[len-1]<='z') { c[j][k]='\0'; j++; } if(a[i]=='#') break; } n=j; for(j=0;j<n-1;j++) for(k=j+1;k<n;k++) if(strcmp(c[j],c[k])==0) {m++;break;} printf("%d\n",n-m); if(a[i]=='#') break; } return 0; }