29、最小的K个数

题目描述
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。

class Solution {
public:
    vector<int> GetLeastNumbers_Solution(vector<int> input, int k) {
        priority_queue<int,vector<int>,less<int>> smallestK; //大顶堆,对头元素最大
     //priority_queue<int,vector<int>,greater<int>> biggestK;//小顶堆,对头元素最小
        int n = input.size();
        vector<int> rec;
        if(n<=0||k<=0||k>n)
            return rec;
        for(int i=0;i<n;i++)
        {
            if(smallestK.size()<k)
                smallestK.push(input[i]);
            if(smallestK.size()==k)
            {
                if(input[i]<smallestK.top())
                {
                    smallestK.pop();
                    smallestK.push(input[i]);
                }    
                
            }
        }
        for(int i=0;i<k;i++)
        {
            rec.push_back(smallestK.top());
            smallestK.pop();
        }
        return rec;
    }
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容