(C++)剑指offer-29:最小的K个数(时间效率)

剑指offer-29:最小的K个数

目录

  • 剑指offer-29最小的K个数
  • 目录
    • 1题目描述
    • 2题目答案

1题目描述

输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
(C++)剑指offer-29:最小的K个数(时间效率)_第1张图片

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;ireturn res;

    }
};

(2)Partition方法???

你可能感兴趣的:(剑指offerC++)