其他分享
首页 > 其他分享> > 场景设计面试题

场景设计面试题

作者:互联网

100亿个数据中找出最大的1000个

海量数据处理,思路基本上是:必须分块处理,然后再合并起来。

1.采用小顶堆算法
我们知道完全二叉树有几个非常重要的特性,就是假如该二叉树中总共有N个节点,那么该二叉树的深度就是log2N,对于小顶堆来说移动根元素到 底部或者移动底部元素到根部只需要log2N,相比N来说时间复杂度优化太多了(1亿的logN值是26-27的一个浮点数)。基本的思路就是先从文件中取出1000个元素构建一个小顶堆数组k,然后依次对剩下的100亿-1000个数字进行遍历m,如果m大于小顶堆的根元素,即k[0],那么用m取代k[0],对新的数组进行重新构建组成一个新的小顶堆。这个算法的时间复杂度是O((100亿-1000)log(1000)),即O((N-M)logM),空间复杂度是M

这个算法优点是性能尚可,空间复杂度低,IO读取比较频繁,对系统压力大。

2.采用分区法
将100亿个数据分成1000个分区,每个分区上1000万个数据,在每个分区上上再细分成100个分区,即总共分成1000*100个分区,然后启动多线程进行处理,各个分区上采用小顶堆算法取出最大的1000个数据,分层进行合并然后重新计算不同层上的最大1000个数,最终递归到最上层。 但linux系统上一个进程能启动的默认线程数是1024个,所以要么调整最大线程数,要么在线程调用处做一些处理,比如一个线程完成一个分区之后再去处理相邻的分区,或者在分区的时候把所有的分区数目限制在1024之内。这个算法切合了map-reduce的思想,利用了多线程和多处理器的优势,减少了多余的比较和IO读取,性能比第一种会更好但算法更复杂一点,要考虑的情况也更多。

标签:面试题,场景,分区,算法,小顶,设计,100,复杂度,1000
来源: https://blog.csdn.net/weixin_43260719/article/details/120811936