杭电OJ-2072_单词数
单词数
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 36915 Accepted Submission(s): 8977
Problem Description
lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。下面你的任务是帮助xiaoou333解决这个问题。
Input
有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。
Output
每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。
Sample Input
you are my friend
#
Sample Output
4
思路:
将一行字符按单词截开存入而为数组,要注意缓冲数组的重置不然会因为上次输入的单词长度大于本次的长度而出错
代码:
#include<iostream>
#include<cstring>
using namespace std;
char bank[256][256];
char art[10000];
char buff[256];
int main()
{
while(cin.getline(art,sizeof(art)))
{
int n=0;
for(int i=0;i<256;i++)
memset(bank[i],'\0',sizeof(bank[i]));
if(strcmp(art,"#")==0) break;
for(int i=0,j=0;;i++,j++)
{
//cout<<"art["<<i<<"]"<<art[i]<<" j:"<<j<<endl;
if(art[i]!=' '&&art[i]!='\0'&&art[i]!='\n') //将整个的单词存入缓冲
{
buff[j]=art[i];
}
else
{
j=-1;
int y=n;
bool sign=true;
for(int x=0;x<=y;x++) //判断缓冲中的单词有没有出现过
{
if(strcmp(bank[x],buff)==0)
{
sign=false;
break;
}
}
if(sign)
{
strcpy(bank[n],buff);
n++;
}
memset(buff,'\0',sizeof(buff)); //重置缓冲数组,不然会干扰下次结果
}
if(art[i]=='\0')
break;
}
/*
for(int i=0;i<n;i++)
cout<<bank[i]<<endl;
*/
cout<<n<<endl;
//cout<<buff<<endl;
}
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步