原文:如何从100万个数中找出最大的前100个数

. 算法如下:根据快速排序划分的思想 递归对所有数据分成 a,b b b,d 两个区间, b,d 区间内的数都是大于 a,b 区间内的数 对 b,d 重复 操作,直到最右边的区间个数小于 个。注意 a,b 区间不用划分 返回上一个区间,并返回此区间的数字数目。接着方法仍然是对上一区间的左边进行划分,分为 a ,b b b ,d 两个区间,取 b ,d 区间。如果个数不够,继续 操作,如果个数超过 ...

2018-04-02 00:12 0 1257 推荐指数:

查看详情

100个整数里找出100最大

  声明:本文最初发表于《电脑编程技巧与维护》2006年第5期,版本所有,如蒙转载,敬请连此声明一起转载,否则追究侵权责任。网上发表于恋花蝶的博客http://lanphaday.bokee.com   题目:从1亿个整数数找出最大的1个。   拿到这道题,马上就会想到的方法是建立一个数 ...

Wed Oct 15 00:48:00 CST 2014 1 2594
100亿个数找出最大的10个

1、首先一点,对于海量数据处理,思路基本上是确定的,必须分块处理,然后再合并起来。 2、对于每一块必须找出10个最大,因为第一块10个最大的最小的,可能比第二块10最大最大的还要大。 3、分块处理,再合并。也就是Google MapReduce 的基本思想。Google ...

Sun Mar 02 23:58:00 CST 2014 2 13785
(算法)从10000个数找出最大的10个

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

Thu Mar 21 05:10:00 CST 2013 10 19235
面试题-10亿个数找出最大的10000个数(top K问题)

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

Fri Mar 06 04:19:00 CST 2020 0 1808
关于“100g文件全是数组,取最大100个数”解决方法汇总

原题如下: 有一个100G大小的文件里存的全是数字,并且每个数字见用逗号隔开。现在在这一大堆数字找出100最大的数出来。 我认为,首先要摸清考官的意图。是想问你os方面的知识,还是算法,或者数据结构。 如果是os: 无疑是外排序算法的选择。100g文件在当前的环境下是无法全部读入 ...

Tue Oct 01 00:42:00 CST 2019 3 483
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM