题解 | #最小的K个数#

最小的K个数

http://www.nowcoder.com/practice/6a296eb82cf844ca8539b57c23e6e9bf

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param input int整型一维数组 
# @param k int整型 
# @return int整型一维数组
#
class Solution:
    def GetLeastNumbers_Solution(self , input: List[int], k: int) -> List[int]:
        # write code here
        # write code here
        import heapq
        tmp = [-i for i in input]
        n = len(tmp)
        heap = []
        if k>n or n==0 or k==0:
            return []
        for i in tmp[:k]:
            heapq.heappush(heap, i)
        for j in tmp[k:n]:
            if j>heap[0]:
                heapq.heapreplace(heap, j)
        return [-i for i in heap]
全部评论

相关推荐

勤奋努力的椰子这就开摆:美团骑手在美团工作没毛病
投递美团等公司10个岗位
点赞 评论 收藏
分享
评论
2
收藏
分享
牛客网
牛客企业服务