标题:求助 c语言作业题不会写
只看楼主
几个一
Rank: 2
等 级:论坛游民
帖 子:23
专家分:39
注 册:2020-10-17
结帖率:100%
已结贴  问题点数:20 回复次数:1 
求助 c语言作业题不会写
实验任务
文献查找一般是通过关键词进行查找的,英文文献的关键词是出现次数最多的单词。现给定一篇英文文献,用一个字符串数组保存,数组的每个元素存储的是文献中的一句话,书的内容不多于10000句。(单词仅由字母构成)
1.实现一个函数,以文献内容和一个单词为参数,统计文献中该单词出现的次数(以参数形式返回给该函数的调用者),并将第一次出现该单词在数组中的位置指针作为返回值。
2. 在上述实现的函数基础上,找出文献的关键词。
搜索更多相关主题的帖子: 单词 关键词 出现 c语言 作业 
2020-12-18 13:24
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:20 
(单词仅由字母构成)
这句话好理解,也就是 aren't、thirty-nine 等要么不出现,要么就分开作为两个单词看待。
但 非单词 呢,或者说是单词间的间隔有哪些? 空格、水平制表符、垂直制表符、回车符、换行符、换页符 有吗?逗号、句号、分号、引号、感叹号…… 有吗?还是只要是 非字母 都算作单词的间隔符?

2. 在上述实现的函数基础上,找出文献的关键词。
不怎么能行吧,难道从头到尾每一个单词再全盘搜一次?那一亿个单词 就要比较 一亿*一亿 次,把一个简单的 O(n) 的算法变成了 O(n*n)。
而且题目没交代每行最多有几个单词,想优化保存记录都做不到。
2020-12-18 14:10



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-504303-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.067490 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved