1.4 查找最大或最小的N个元素
问题
集合里面,求最大或者最小的 N 个元素
解决
heapq模块有两个函数:nlargest()
和 nsmallest()
可以完美解决这个问题。(其实就是利用了堆这个数据结构的性质)
可以使用 key
参数,以支持更复杂的数据结构:
讨论
在底层实现里面,首先会先将集合数据进行堆排序后放入一个列表中:
堆数据结构最重要的特征是 heap[0]
永远是最小的元素。并且剩余的元素可以很容易的通过调用 heapq.heappop()
方法得到, 该方法会先将第一个元素弹出来,然后用下一个最小的元素来取代被弹出元素(这种操作时间复杂度仅仅是O(log N),N是堆大小)。
如果你仅仅想查找唯一的最小或最大(N=1)的元素的话,那么使用 min()
和 max()
函数会更快些。 类似的,如果N的大小和集合大小接近的时候,通常先排序这个集合然后再使用切片操作会更快点 ( sorted(items)[:N]
或者是 sorted(items)[-N:]
)。
Last updated
Was this helpful?