• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

最大K个数问题的Python版解法

python 搞代码 4年前 (2022-01-09) 26次浏览 已收录 0个评论

TopK问题,即寻找最大的K个数,这个问题非常常见,比如从1千万搜索记录中找出最热门的10个关键词.

方法一:
先排序,然后截取前k个数.
时间复杂度:O(n*logn)+O(k)=O(n*logn)。
这种方式比较简单粗暴,提一下便是。

方法二:最大堆

我们可以创本文来源gaodai$ma#com搞$$代**码)网8建一个大小为K的数据容器来存储最小的K个数,然后遍历整个数组,将每个数字和容器中的最大数进行比较,如果这个数大于容器中的最大值,则继续遍历,否则用这个数字替换掉容器中的最大值。这个方法的理解也十分简单,至于容器的选择,很多人第一反应便是最大堆,但是python中最大堆如何实现呢?我们可以借助实现了最小堆的heapq库,因为在一个数组中,每个数取反,则最大数变成了最小数,整个数字的顺序发生了变化,所以可以给数组的每个数字取反,然后借助最小堆,最后返回结果的时候再取反就可以了,代码如下:

import heapqdef get_least_numbers_big_data(self, alist, k):  max_heap = []  length = len(alist)  if not alist or k <= 0 or k > length:    return  k = k - 1  for ele in alist:    ele = -ele    if len(max_heap) <= k:      heapq.heappush(max_heap, ele)    else:      heapq.heappushpop(max_heap, ele)  return map(lambda x:-x, max_heap)if __name__ == "__main__":  l = [1, 9, 2, 4, 7, 6, 3]  min_k = get_least_numbers_big_data(l, 3)

方法三:quick select

quick select算法.其实就类似于快排.不同地方在于quick select每趟只需要往一个方向走.
时间复杂度:O(n).

def qselect(A,k):   if len(A)<k:return A   pivot = A[-1]   right = [pivot] + [x for x in A[:-1] if x>=pivot]   rlen = len(right)   if rlen==k:     return right   if rlen>k:     return qselect(right, k)   else:     left = [x for x in A[:-1] if x<pivot]     return qselect(left, k-rlen) + right  for i in range(1, 10):   print qselect([11,8,4,1,5,2,7,9], i)

更多最大K个数问题的Python版解法相关文章请关注搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:最大K个数问题的Python版解法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址