代码题(3)— 最小的k个数、数组中的第K个最大元素、前K个高频元素

  1、题目:输入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) {
        vector<int> result;
        if(input.empty() || k<=0 || input.size()<k)
            return result;
        int low = 0;
        int high = input.size() - 1;
        int index = partition(input, low, high);
        while(index != k-1)
        {
            if(index <= k-1 )
            {
                low = index + 1;
                index = partition(input, low, high);
            }
            else 
            {
                high = index - 1;
                index = partition(input, low, high);
            }
        }
        for(int i =0; i<k; ++i)
        {
            result.push_back(input[i]);
        }
        return result;
    }
    int partition(vector<int> &input, int low, int high)
    {
        int temp = input[low];
        while(low < high)
        {
            while(low<high && temp < input[high])
                high--;
            input[low] = input[high];
            while(low<high && temp >=input[low])
                low++;
            input[high] = input[low];
        }
        input[low] = temp;
        return low;
    }
};

  使用容器的方法:

class Solution {
public:
    vector<int> GetLeastNumbers_Solution(vector<int> input, int k) {
        vector<int> result;
        if(input.empty() || k<1 || input.size()<k)
            return result;
        priority_queue<int> pq;
        for(int i=0;i<input.size();i++)
        {
            if(pq.size()<k)
            {
                pq.push(input[i]);
            }
            else
            {
                int maxVal=pq.top();
                if(input[i]<maxVal)
                {
                    pq.pop();
                    pq.push(input[i]);
                }
            }
        }
        while(!pq.empty())
        {
            result.push_back(pq.top());
            pq.pop();
        }
        return result;
        
    }
};

2、215、数组中的第K个最大元素

题目:在未排序的数组中找到第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

示例 1:

输入: [3,2,1,5,6,4] 和 k = 2
输出: 5

示例 2:

输入: [3,2,3,1,2,4,5,5,6] 和 k = 4
输出: 4
class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        if(nums.empty() || nums.size() < k)
            return -1;
        int low = 0;
        int high = nums.size() - 1;
        int index = partition(nums,low,high);
        while(index != k-1 && low<high){
            if(index < k-1){
                low = index + 1;
                index = partition(nums,low,high);
            } else {
                high = index - 1;
                index = partition(nums,low,high);
            }
        }
        return nums[index];
    }

    int partition(vector<int>& nums,int low, int high){
        int temp = nums[low];
        while(low<high){
            while(low < high && temp > nums[high]){  // 此处是从大到小排列数组
                high--;
            }
            nums[low]  = nums[high];
            while(low < high && temp <= nums[low]){
                low++;
            }
            nums[high] = nums[low];
        }
        nums[low] = temp;
        return low;
    }
};

 3、347. 前K个高频元素

给定一个非空的整数数组,返回其中出现频率前 高的元素。

示例 1:

输入: nums = [1,1,1,2,2,3], k = 2
输出: [1,2]

示例 2:

输入: nums = [1], k = 1
输出: [1]

说明:

  • 你可以假设给定的 总是合理的,且 1 ≤ k ≤ 数组中不相同的元素的个数。
  • 你的算法的时间复杂度必须优于 O(n log n) , 是数组的大小。
class Solution {
public:
    vector<int> topKFrequent(vector<int>& nums, int k) {
        unordered_map<int, int> m;
        priority_queue<pair<int,int>> q;
        vector<int> res;
        
        for(int a:nums)
            m[a]++;
        for(auto it:m)
            q.push({it.second, it.first});
        for(int i=0;i<k;++i)
        {
            res.push_back(q.top().second);
            q.pop();
        }
        return res;
    }
};

 

posted @ 2018-06-20 20:59  深度机器学习  阅读(279)  评论(0编辑  收藏  举报