栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在Python中大小为N的未排序列表中获取k个最小数字的最快方法?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在Python中大小为N的未排序列表中获取k个最小数字的最快方法?

您可以使用堆队列;在O(NlogK)时间中,它可以从大小N的列表中为您提供K个最大或最小的数字。

Python标准库包含

heapq
模块,并带有已实现的
heapq.nsmallest()
功能:

import heapqk_smallest = heapq.nsmallest(k, input_list)

在内部,这将使用输入列表的前K个元素创建大小为K的堆,然后遍历其余的NK个元素,将每个元素推入堆,然后弹出最大的一个。这样的推入和弹出操作花费日志K时间,从而使总体操作为O(NlogK)。

该功能还优化了以下边缘情况:

  • 如果K为1,
    min()
    则使用该函数,结果为O(N)。
  • 如果K> = N,则该函数改用排序,因为在这种情况下O(NlogN)会胜过O(NlogK)。

更好的选择是使用introselect算法,该算法提供O(n)选项。我知道的唯一实现是使用

numpy.partition()
功能:

import numpy# assuming you have a python list, you need to convert to a numpy array firstarray = numpy.array(input_list)# partition, slice back to the k smallest elements, convert back to a Python listk_smallest = numpy.partition(array, k)[:k].tolist()

除了需要安装之外

numpy
,这还占用了N个内存(相对于K而言
heapq
),因为为分区创建了列表的副本。

如果只需要索引,则可以将其用于任一变体:

heapq.nsmallest(k, range(len(input_list)), key=input_list.__getitem__)  # O(NlogK)numpy.argpartition(numpy.array(input_list), k)[:k].tolist()  # O(N)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/645877.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号