algo/python/28_binary_heap/top_k.py

40 lines
688 B
Python
Raw Normal View History

2018-11-28 16:45:04 +08:00
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import random
from heap import MinHeap
def top_k(nums, k):
"""
返回数组的前k大元素
:param nums:
:param k:
:return:
"""
if len(nums) <= k:
return nums
min_h = MinHeap(nums[:k], k)
for i in range(k, len(nums)):
tmp = min_h.get_top()
if nums[i] > tmp:
min_h.remove_top()
min_h.insert(nums[i])
return min_h.get_data()
if __name__ == '__main__':
nums = []
k = 3
for i in range(20):
nums.append(random.randint(1, 100))
print('--- nums ---')
print(nums)
print('--- top {} ---'.format(k))
print(top_k(nums, k))