剑指offer-29:最小的K个数
目录
1题目描述
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
2题目答案
基于堆排序算法,构建最大堆。时间复杂度为O(nlogk)
如果用快速排序,时间复杂度为O(nlogn);
如果用冒泡排序,时间复杂度为O(n*k)
(1)全排序 时间复杂度O(nlogn)
class Solution {
public:
vector<int> GetLeastNumbers_Solution(vector<int> input, int k) {
vector<int> res;
if(input.empty()||k>input.size()) return res;
sort(input.begin(),input.end());
for(int i=0;i<k;i++)
res.push_back(input[i]);
return res;
}
};
(2)Partition方法???