有一个名为topnews.txt的包括若干条英语新闻的文本文件,其中,每条新闻占一个文本段(以回车换行结束).请用类c语言编写程序,统计其中各英语单词的出现频率,并按词频降序排列所有单词.(假设文本文件中所有新闻的长度总和不超过10000个单词,文本文件以IA结束)
1条回答 默认 最新
- jinqmao 2013-12-03 07:17关注
代码就不写了,描述算法,希望还能赶上用
数据结构:双双向指针链表,注意首尾都需要
stuct struct1
{
short count; /*计数*/
short strLen; /*字符串长度*/
char word[16]; /*字符串*/
struct1 wordH; /字典序前面一个单词*/
struct1 wordE; /字典序后面一个单词*/
struct1 countH; /排序前面一个计数*/
struct1 countE; /排序后面一个计数*/
};
算法:
每个单词,按字典序升序那个查找链表,使用这个链表的目的是提高插入效率
找到,count++,维护计数链表;
否则,申请节点内存,写入信息,维护字典序链表,计数链表挂最后;
循环插入完成后,按计数链表输出即可。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 如何在scanpy上做差异基因和通路富集?
- ¥20 关于#硬件工程#的问题,请各位专家解答!
- ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
- ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
- ¥30 截图中的mathematics程序转换成matlab
- ¥15 动力学代码报错,维度不匹配
- ¥15 Power query添加列问题
- ¥50 Kubernetes&Fission&Eleasticsearch
- ¥15 報錯:Person is not mapped,如何解決?
- ¥15 c++头文件不能识别CDialog