LeetCode刷题笔记-数据结构-day20

LeetCode刷题笔记-数据结构-day20

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

1.题目

原题链接:215. 数组中的第K个最大元素

image-20220203093144515

2.解题思路

直接套快排模板:

void quick_sort(int q[], int l, int r)
{
    
    
    if (l >= r) return;

    int i = l - 1, j = r + 1, x = q[l + r >> 1];
    while (i < j)
    {
    
    
        do i ++ ; while (q[i] < x);
        do j -- ; while (q[j] > x);
        if (i < j) swap(q[i], q[j]);
    }
    quick_sort(q, l, j), quick_sort(q, j + 1, r);
}

3.代码

class Solution {
    
    
    public:
    int quickSort(vector<int>& nums,int l,int r,int k){
    
    
        if(l>=r) return nums[k];
        int x=nums[l+r>>1],i=l-1,j=r+1;
        while(i<j){
    
    
            do i++; while(nums[i]>x);
            do j--; while(nums[j]<x);
            if(i<j) swap(nums[i],nums[j]);
        }
        if(k<=j) return quickSort(nums,l,j,k);
        else return quickSort(nums,j+1,r,k);
    }
    int findKthLargest(vector<int>& nums, int k) {
    
    
        return quickSort(nums,0,nums.size()-1,k-1);
    }
};

347. 前 K 个高频元素

1.题目描述

原题链接:347. 前 K 个高频元素

image-20220203093219688

2.解题思路

算法:哈希表+计数排序

具体实现:

  1. 首先使用哈希表统计所有数出现的次数
  2. 用计数排序,统计出出现次数最多的前k个元素的下界
  3. 最后遍历哈希表,将出现次数大于下界的数加入答案

3.代码

class Solution {
    
    
public:
    vector<int> topKFrequent(vector<int>& nums, int k) {
    
    
        int n=nums.size();
        map<int,int> hash;
        for(auto x:nums) hash[x]++;
        vector<int> s(n+1);
        for(auto [a,b]:hash) s[b]++;
        int i=n,t=0;
        while(t<k) t+=s[i--];
        vector<int> res;
        for(auto [a,b]:hash){
    
    
            if(b>i) res.push_back(a);
        }
        return res;
    }
};

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_45966440/article/details/122774418