注册 登录
编程论坛 C语言论坛

求助 c语言作业题不会写

几个一 发布于 2020-12-18 13:24, 1683 次点击
实验任务
文献查找一般是通过关键词进行查找的,英文文献的关键词是出现次数最多的单词。现给定一篇英文文献,用一个字符串数组保存,数组的每个元素存储的是文献中的一句话,书的内容不多于10000句。(单词仅由字母构成)
1.实现一个函数,以文献内容和一个单词为参数,统计文献中该单词出现的次数(以参数形式返回给该函数的调用者),并将第一次出现该单词在数组中的位置指针作为返回值。
2. 在上述实现的函数基础上,找出文献的关键词。
1 回复
#2
rjsp2020-12-18 14:10
(单词仅由字母构成)
这句话好理解,也就是 aren't、thirty-nine 等要么不出现,要么就分开作为两个单词看待。
但 非单词 呢,或者说是单词间的间隔有哪些? 空格、水平制表符、垂直制表符、回车符、换行符、换页符 有吗?逗号、句号、分号、引号、感叹号…… 有吗?还是只要是 非字母 都算作单词的间隔符?

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