python - 在列表中找到第 n 个最小的数字?

标签 python list python-2.7

我需要一种有效的方法来获取第 n 个最小的数字及其在包含多达 15000 个实体的列表中的索引(因此速度不是 super 关键)。

很遗憾,我不能使用 numpy 或任何其他非标准库。

我正在使用 Python 2.7

最佳答案

使用heapq.nsmallest(和enumerate获取索引):

nums = [random.randint(1,1000000) for _ in range(10000)]

import heapq
import operator

heapq.nsmallest(10,enumerate(nums),key=operator.itemgetter(1))
Out[26]: 
[(5544, 35),
 (1702, 43),
 (6547, 227),
 (1540, 253),
 (4919, 360),
 (7993, 445),
 (1608, 495),
 (5832, 505),
 (1388, 716),
 (5103, 814)]

关于python - 在列表中找到第 n 个最小的数字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21442460/

相关文章:

python - 如何处理不存在的装饰器

c++ - C++ 中有 "generics-like"功能吗?

CSS:子菜单绝对定位的子菜单

python - 使用 Swig 和 distutils 为 Python 3 构建扩展

python - 获取 Unix/Linux 远程主机支持的文件/目录信息的最佳方法是什么

python - 处理七张牌扑克时计算的单对概率的异常概率结果

python - 即使字典键中存在属性,getattr 也会返回默认值

python-2.7 - 如果使用 opencv 调整大小方法,pytorch 数据加载器会卡住

python - numpy.fft.fft 的功率谱

c# - 将JSON的每个解析值存储到一个数组中