原文:利用最小堆找出10亿个数中最大的10000个数

最小堆 最小堆是一种完全二叉树,特点是根节点比两个子节点都小 或者根节点比子节点都大 过程 先找 个数构建最小堆 依次遍历 亿个数,如果比最小堆的最小值大,则替换这个最小值,并重新构建最小堆 最后输入 个值 时间复杂度 构建最小堆的复杂度为 logn,求出最大m个数会构建m次最小堆,时间复杂度为 m logm, 这里m为 进行n次时间复杂度为n,这里n为 亿,总时间复杂度为 n m logm,即 ...

2018-05-01 10:53 0 2403 推荐指数:

查看详情

面试题-10亿个数找出最大10000个数(top K问题)

一个较好的方法:先拿出10000个建立小根堆,对于剩下的元素,如果大于堆顶元素的值,删除堆顶元素,再进行插入操作,否则直接跳过,这样知道所有元素遍历完,堆中的10000个就是最大10000个。时间复杂度: m + (n-1)logm = O(nlogm) 优化的方法:可以把所有10亿个数据分组 ...

Fri Mar 06 04:19:00 CST 2020 0 1808
海量数据处理 - 10亿个数找出最大10000个数(top K问题)

前两天面试3面学长问我的这个问题(想说TEG的3个面试学长都是好和蔼,希望能完成最后一面,各方面原因造成我无比想去鹅场的心已经按捺不住了),这个问题还是建立最小堆比较好一些。 先拿10000个数建堆,然后一次添加剩余元素,如果大于堆顶的10000中最小的),将这个数替换堆顶 ...

Sat Feb 16 04:10:00 CST 2019 2 5644
(算法)从10000个数找出最大10

  从10000个整数中找出最大10个,最好的算法是什么? 算法一:冒泡排序法   千里之行,始于足下。我们先不说最好,甚至不说好。我们只问,如何“从10000个整数中找出最大10个”?我最先想到的是用冒泡排序的办法:我们从头到尾走10趟,自然会把最大10个数找到。方法简单,就不再这里写 ...

Thu Mar 21 05:10:00 CST 2013 10 19235
输入10个整数,将其中最小与第一个数对换, 把最大与最后一个数对换

输入10个整数,将其中最小与第一个数对换, 把最大与最后一个数对换。 点我看视频讲解+可运行代码,记得收藏视频,一键三连 写3个函数: ①输人10个数; ②进行处理; ③输出10个数。 解题思路: 在进行数值逐个比较的同时找到最小值的空间地址以及最大值的空间地址,使用这两个空间 ...

Fri Jul 10 02:31:00 CST 2020 0 874
输入10个整数,将其中最小与第一个数对换, 把最大与最后一个数对换

输入10个整数,将其中最小与第一个数对换, 把最大与最后一个数对换 写3个函数: ①输人10个数; ②进行处理; ③输出10个数。 解题思路: 在进行数值逐个比较的同时找到最小值的空间地址以及最大值的空间地址,使用这两个空间中的数据最终与第一和最后数据进行对换即可。 答案: ...

Tue Jul 28 00:24:00 CST 2020 0 770
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM