海量数据常见的面试题(频次最高+随机抽样)

本文探讨了在处理海量数据时如何统计出现次数最多的n个元素,针对内存能容纳数据和不能容纳数据两种情况进行了解析。另外,文章还详细介绍了在数据流场景下,如何进行随机抽样的蓄水库抽样方法,保证每个数据被抽中的概率相等。
摘要由CSDN通过智能技术生成

在海量数据中统计出现次数最多的n个

 分两种情况,

  1 如果数据能够在内存中放下,比如如果海量数据是ip地址,最多有4G个ip地址,每个ip地址占4个字节 需要内存16G,如果内存在几十G,则完全可以全部装入内存,

   直接读取大文件,然后创建一个hash表,统计次数,最后再用堆统计最大的n个


2  如果不能在内存放下,比如海量数据是字符串,不同的字符串个数无限,内存中可能存不下,那么需要先将海量数据进行分堆,按照hash值进行分堆,分成适宜在内存中操作的小文件,比如内存1G,字符串有20G,那么就分成20个以上的小文件

为什么要用hash分堆,这样是为了保证同一个字符串只会出现在同一个文件



【随机抽样问题】
要求从N个元素中随机的抽取k个元素,其中N无法确定。
这种应用的场景一般是数据流的情况下,由于数据只能被读取一次,而且数据量很大,并不能全部保存,因此数据量N是无法在抽样开始时确定的;但又要保持随机性,于是有了这个问题。所以搜索网站有时候会问这样的问题。
这里的核心问题就是“随机”,怎么才能是

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值