现在的位置: 首页 > 综合 > 正文

编程之美上的寻找最大的前k个数的算法实现

2019年03月20日 ⁄ 综合 ⁄ 共 1895字 ⁄ 字号 评论关闭

   编程之美上的寻找N个数中最大的前K数,给出了一种算法,我认为比较好:
  算法是这样写的:

   假设N个数存储在数组S中,我们从数组S中随机选出一个元素X,把数组分为两部分Sa和Sb.Sa中的元素都大于X,Sb中的元素都小于X,这时,有两种可能性:
1.Sa中元素的个数小于K,Sa中所有的数和Sb中最大的K-|Sa|个数(|Sa|指Sa中元素的个数)就是数组S中最大的K个数。
2.Sa中元素的个数大于或等于K,则直接返回Sa中最大的K个元素。

平均时间复杂度O(N*log2 K)

伪代码

我的实现

【上篇】
【下篇】

抱歉!评论已关闭.