LeetCode刷题笔记-数据结构-day20
Posted LL.LEBRON
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode刷题笔记-数据结构-day20相关的知识,希望对你有一定的参考价值。
文章目录
LeetCode刷题笔记-数据结构-day20
215. 数组中的第K个最大元素
1.题目
原题链接:215. 数组中的第K个最大元素
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 个高频元素
2.解题思路
算法:哈希表+计数排序
具体实现:
- 首先使用哈希表统计所有数出现的次数
- 用计数排序,统计出出现次数最多的前k个元素的下界
- 最后遍历哈希表,将出现次数大于下界的数加入答案
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;
;
以上是关于LeetCode刷题笔记-数据结构-day20的主要内容,如果未能解决你的问题,请参考以下文章