leetcodehot100-347. 前 K 个高频元素

复制代码
class Solution {
public:
    vector<int> topKFrequent(vector<int>& nums, int k) {
        map<int,int> mp;
        for(int i=0;i<nums.size();i++){
            mp[nums[i]]++;
        }
//// 更好的写法(用 unordered_map)
//unordered_map<int,int> mp;  // O(n) 平均,不排序,更快
//for(int num : nums) mp[num]++;
        auto cmp = [](const pair<int, int>& a, const pair<int, int>& b) {
            return a.second > b.second;
        };//按 second 降序
        priority_queue<pair<int,int>,vector<pair<int,int>>,decltype(cmp)> pq(cmp);
        for(auto it:mp){
            pq.push(it);
            if(pq.size()>k) pq.pop();//把概率最小的pop
        }
        vector<int> ans(k);
        for(int i=k-1;i>=0;i--){
            ans[i]=pq.top().first;
            pq.pop();
        }
        return ans;
    }
};

map 在这里的作用

  • 只负责统计频率(key → 元素,value → 频率)

  • 不需要排序 ,因为后续会用 priority_queue 排序

特性 map unordered_map
底层实现 红黑树(平衡二叉搜索树) 哈希表
元素顺序 自动按键排序(升序) 无序
时间复杂度 插入/查找/删除:O(log n) 平均 O(1),最坏 O(n)
空间占用 较小 较大(需要维护哈希表)
自定义类型 需要定义 operator< 需要定义哈希函数和相等比较

priority_queue 的作用

  • 真正负责按频率排序

  • 维护大小为 k 的小顶堆,保存频率最高的 k 个元素

复制代码
// priority_queue 默认是大顶堆
// 比较函数返回 true 时,b 应该在 a 上面
// 所以降序用 <,升序用 >

// 降序(最大堆)
return a.second < b.second;   // 大的在上

// 升序(最小堆)
return a.second > b.second;   // 小的在上
  • 含义 :比较函数的类型(注意是类型,不是函数对象本身)

  • decltype:获取 lambda 表达式的类型

复制代码
// ❌ 错误:不能直接传 lambda 对象
priority_queue<pair<int,int>, vector<pair<int,int>>, 
               [](auto& a, auto& b){ return a.second < b.second; }> pq;
复制代码
void sort(RandomIt first, RandomIt last, Compare comp);
//                                          ^^^^^^^^^^^^
//                                          这是函数参数,可以传对象!
复制代码
// 1. 定义比较器类型
using CompareType = decltype(cmp);  // cmp 的类型

// 2. 创建 priority_queue 对象,并传入 cmp 对象
priority_queue<pair<int, int>, vector<pair<int, int>>, CompareType> pq2(cmp);
//                                                                     ^^^^^
//          
相关推荐
吴可可123几秒前
AutoCAD2016二次开发环境配置指南
算法·机器学习
一条大祥脚3 分钟前
ABC461 枚举|扫描线|动态前缀和|数论|dfs枚举子集
算法·深度优先
计算机安禾7 分钟前
【数据库系统原理】第14篇:关系模式的语义约束:函数依赖的公理系统与闭包计算
人工智能·算法·机器学习
量化君也8 分钟前
快速入门量化交易都要学些什么?
大数据·人工智能·python·算法·金融
AbandonForce19 分钟前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
炸薯条!31 分钟前
二叉树的链式表示(2)
java·数据结构·算法
Tairitsu_H34 分钟前
[LC优选算法#2] 滑动窗口 | 长度最小的子数组 | 无重复字符的最长子串 | 最大连续1的个数
算法
小欣加油36 分钟前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
下午写HelloWorld43 分钟前
【概念与应用】轻量级加密算法LEA、动态脱敏算法DDA、零知识证明ZKP和优化协同交互协议OCIP
算法·区块链·密码学·安全架构·零知识证明
飞舞哲1 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab