统计英文单词数(C++语言)注:满足所有条件 给出一篇英文文章,文件不小于1MB的大小。统计其中的

统计英文单词数(C++语言)注:满足所有条件
给出一篇英文文章,文件不小于1MB的大小。统计其中的每个不同英文单词和总单词的数量。
实现提示:分别用链表和哈希表来实现,注意要给出不同大小文件耗费的时间,对时间性能进行进一步分析。关于英文文章,请自动生成文本文件。也可以从网络上下载几篇英文的文章,然后合并生成。

#include<stdio.h>
#include<string.h>
int num(char *str);
int juzs(char *str,int*p);
int main()
{
int word,jzs,max;
char a[10000];
printf("请输入英文文章:\n");
gets(a);
word=num(a);
jzs=juzs(a,&max);
printf("这篇文章中有%d个单词,有%d个句子,最长的句子中有%d个单词",word,jzs,max);
return 0;

}
int num(char *str)
{
int flag=0,i=0,j=0;
while(str[i]!='\0')
{
if(str[i]>='A'&&str[i]<='Z'||str[i]>='a'&&str[i]<='z')
flag++;
else flag=0;
if(flag==1)j++;
i++;
}
return j;
}
int juzs(char *str,int*max)
{
int i=0,flag=0,j=0,m=0;
*max=0;
while(str[i]!='\0')
{
while(str[i]!='.')
{
if(str[i]>='A'&&str[i]<='Z'||str[i]>='a'&&str[i]<='z')
m++;
else m=0;
if(m==1)(*max)++;
i++;
}
if(j<(*max))j=*max;
i++;
*max=0;
flag++;
}
*max=j;
return flag;
}
温馨提示:答案为网友推荐,仅供参考
相似回答
大家正在搜