LeetCode刷题——347. 前 K 个高频元素

✊✊✊🌈大家好!本篇文章将较详细介绍栈的题目347.前 K 个高频元素,主要记录小顶堆的使用方式,代码语言为:C++代码😇。


347. 前 K 个高频元素

🔒1、题目:

给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。
🌲 示例 1🌲:

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

🌲 示例 2🌲:

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

❗️ 提示 ❗️ :

  • 1 <= nums.length <= 105
  • k 的取值范围是 [1, 数组中不相同的元素的个数]
  • 题目数据保证答案唯一,换句话说,数组中前 k 个高频元素的集合是唯一的

来源:力扣(LeetCode)👈

☀️2、思路:

1.遍历nums数组,哈希表mp记录每个数字出现的次数
2.利用queue先进优先小顶堆q,遍历mp,得到代表mp中前k大的数字的数组
3.倒序取出前k个频率最大的数存入vector数组

复杂度分析
⏳时间复杂度 O(NlogK)
🏠空间复杂度 O(N)

🔑3、代码:

class Solution {
public:
	    //1.
	    // class mycomparison {
	    // public:
	    //     bool operator()(const pair<int, int>& lhs, const pair<int, int>& rhs) {
	    //         return lhs.second > rhs.second;
	    //     }
	    // };
	    //2.
	    static bool cmp(pair<int,int>&a,pair<int,int>&b){
		        return a.second > b.second;
	    }
	
	    vector<int> topKFrequent(vector<int>& nums, int k) {
	        vector<int> ans(k);
	        unordered_map<int,int> mp;
	        for(auto num:nums) mp[num]++;//哈希表记录元素出现的次数
	
	        //大小为k的小顶堆
	        //1.
	        //priority_queue<pair<int, int>, vector<pair<int, int>>, mycomparison> pri_q;
	        //2.
	        priority_queue<pair<int, int>, vector<pair<int,int>>,decltype(&cmp)>pri_q(cmp); 
	
	        // 用固定大小为k的小顶堆,扫面所有频率的数值
	        for (auto it = mp.begin(); it != mp.end(); it++) {
	            pri_q.push(*it);
	            if (pri_q.size() > k) { // 如果堆的大小大于了K,则队列弹出,保证堆的大小一直为k
	                pri_q.pop();
	            }
	        }
	        //倒序取出前K个频率最大的数
	        for(int i = k - 1; i >= 0; i--){
	            ans[i]=pri_q.top().first;
	            pri_q.pop();
	        }
	        return ans;
	    }
	};

定义小顶堆的两种方式:
1.类

	class mycomparison {
	public:
		bool operator()(const pair<int, int>& lhs, const pair<int, int>& rhs) {
			return lhs.second > rhs.second;
		}
	};
	
	priority_queue<pair<int, int>, vector<pair<int, int>>, mycomparison> pri_q;

2.静态函数

	static bool cmp(pair<int,int>&a,pair<int,int>&b){
		return a.second > b.second;
	}
	priority_queue<pair<int, int>, vector<pair<int,int>>,decltype(&cmp)>pri_q(cmp); 

注意decltype(&cmp) ,要用引用。

相关推荐

  1. LeetCode——347. K 高频元素

    2024-03-22 16:02:02       45 阅读
  2. LeetCode-热100:347. K 高频元素

    2024-03-22 16:02:02       36 阅读
  3. Leetcode 347K高频元素

    2024-03-22 16:02:02       22 阅读
  4. LeetCode Hot100 347.k高频元素

    2024-03-22 16:02:02       59 阅读
  5. 【排序算法】LeetCode-347. K 高频元素

    2024-03-22 16:02:02       50 阅读
  6. 【堆】Leetcode 347. K 高频元素【中等】

    2024-03-22 16:02:02       36 阅读
  7. 347. K 高频元素

    2024-03-22 16:02:02       48 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-22 16:02:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-22 16:02:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-22 16:02:02       82 阅读
  4. Python语言-面向对象

    2024-03-22 16:02:02       91 阅读

热门阅读

  1. 下载NLP_gluedata数据集的脚本

    2024-03-22 16:02:02       36 阅读
  2. 类似于 FastAdmin的快速后台开发框架都有哪些

    2024-03-22 16:02:02       39 阅读
  3. k8s工作节点主要模块

    2024-03-22 16:02:02       38 阅读
  4. 大数据开发(HBase真题)

    2024-03-22 16:02:02       35 阅读
  5. Puppet 2024年度报告:平台工程发掘 DevOps 无限潜质

    2024-03-22 16:02:02       42 阅读
  6. 后台发送GET/POST方法

    2024-03-22 16:02:02       41 阅读
  7. Qt Excel文件读写

    2024-03-22 16:02:02       38 阅读
  8. 9. Linux 信号详解

    2024-03-22 16:02:02       46 阅读
  9. 在Linux/Ubuntu/Debian中创建自己的命令快捷方式

    2024-03-22 16:02:02       42 阅读
  10. 以太网网络变压器

    2024-03-22 16:02:02       37 阅读