栈与队列 Leetcode 347 前k个高频元素

栈与队列 Leetcode 347 前k个高频元素

Leetcode 347

灵活运用C++库函数,使用匿名函数排序,sort可以替换为快排实现(面试感觉可能会手撕,机考直接使用sort)

cpp 复制代码
class Solution {
public:
    vector<int> topKFrequent(vector<int>& nums, int k) {
        map<int, int> num_f;
        for(int i = 0; i < nums.size(); i++){
            num_f[nums[i]]++;
        }
        vector<pair<int, int>> num_f_vec;
        map<int, int>::iterator it;
        for(it = num_f.begin(); it != num_f.end(); it++){
            // push_back()是创建对象后在复制到vector末尾,而emplace_back是就地构建对象没有复制和移动的操作,提高复杂对象到vector的性能
            num_f_vec.emplace_back(it->first, it->second);
        }
        sort(num_f_vec.begin(), num_f_vec.end(), [](pair<int, int>& a, pair<int, int>& b){
            return a.second > b.second;
        });
        vector<int> res;
        for(int i = 0; i < k; i++){
            res.push_back(num_f_vec[i].first);
        }
        return res;
    }
};
相关推荐
不知名的老吴10 分钟前
二叉树的遍历算法之先序遍历
算法
liu****11 分钟前
第16届国赛蓝桥杯大赛C/C++大学B组
c语言·数据结构·c++·算法·蓝桥杯
SimpleLearingAI28 分钟前
大模型推理框架总结解析
算法
ChoSeitaku32 分钟前
04.数组
java·开发语言·数据结构
Σίσυφος190032 分钟前
正则化数据并校准数据
人工智能·算法·机器学习
HZ·湘怡35 分钟前
基于动态数组的栈(顺序栈)01
数据结构·算法
nazisami35 分钟前
红黑树详解
数据结构·c++·面向对象·红黑树
Chen_harmony37 分钟前
十八、C语言内存函数
c语言·算法
雁迟1 小时前
第九章:列表 List 数据类型
数据结构·r语言
m0_547486661 小时前
郑州轻工业大学《数据结构》期末试卷及答案2018-2022学年(AB卷)
数据结构·期末试卷·郑州轻工业大学