用python输出n个数字排大小_在python中获取大小为N的未排序列表中获取k个最小数字的最快方法?...

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

import heapq

k_smallest = heapq.nsmallest(k, input_list)

在内部,这会创建一个大小为K的堆,其中包含输入列表的前K个元素,然后迭代剩余的N-K个元素,将每个元素推送到堆中,然后弹出最大的元素.这样的推送和弹出需要记录K时间,使得整个操作O(NlogK).

该函数还优化了以下边缘情况:

>如果K为1,则使用min()函数,给出O(N)结果.

>如果K> = N,则函数使用排序,因为在这种情况下O(NlogN)将击败O(NlogK).

import numpy

# assuming you have a python list, you need to convert to a numpy array first

array = numpy.array(input_list)

# partition, slice back to the k smallest elements, convert back to a Python list

k_smallest = numpy.partition(array, k)[:k].tolist()

除了需要安装numpy之外,这还需要N个内存(与heapq相比为K),因为为分区创建了列表的副本.

如果您只想要索引,则可以使用以下任一变量:

heapq.nsmallest(k, range(len(input_list)), key=input_list.__getitem__) # O(NlogK)

numpy.argpartition(numpy.array(input_list), k)[:k].tolist() # O(N)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值