大数据类算法问题

1.有一个1G大小的一个文件,里面每一行是一个词,词的大小不超过16字节,内存限制大小是1M。返回频数最高的100个词

1G有2^26个单词,1M可以存2^16个词。

step1:利用hash散列方法,hash(x)/5000将文件单词存到5000个不同的空间。(平均下来,每个空间大概有200k大小,有的可能超过1M,则对于该集合继续划分,知道都小于1M)

step2:将每个集合放入内存进行hashmap处理,key设为单词,value为频率。

step3:对于每个集合,通过最小堆排序的算法求其平率最高的100个。然后将这5000个进行归并排序。(5000*100=500000<2^16)

转载于:https://www.cnblogs.com/wuleh/p/8290019.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值