题解 | #最小的K个数#

最小的K个数

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

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param input int整型一维数组 
# @param k int整型 
# @return int整型一维数组
#
from typing import List
import heapq

class Solution:
    def GetLeastNumbers_Solution(self , input: List[int], k: int) -> List[int]:
        # write code here
        if k == 0:
            return []
        heap = []
        for x in input:
            if len(heap) >= k:
                if -heap[0] > x:
                    heapq.heapreplace(heap, -x)
            else:
                heapq.heappush(heap, -x)
        return list(-item for item in heap)

算法刷题记录 文章被收录于专栏

刷题,记录牛客的101

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务