LeetCode热题100-前 K 个高频元素

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

哈希统计 + 小顶堆思路:

  1. 先用字典统计每个数字出现次数
  2. 大小为 K 的小顶堆保存频率最高的 K 个
  3. 最后取出堆中元素
  4. 时间复杂度 O(n log k)
python 复制代码
import heapq
from collections import Counter
class Solution:
    def topKFrequent(self, nums: List[int], k: int) -> List[int]:
        count = Counter(nums)
        topk = heapq.nlargest(k, count.keys(), key=lambda x:count[x])

        return topk
相关推荐
周末也要写八哥2 小时前
深度剖析:动态规划的分类及实例
算法·动态规划
星马梦缘2 小时前
离散数学——二元关系 作战记录
算法·离散数学
LDG_AGI2 小时前
【搜索引擎】Elasticsearch(五):prefix前缀匹配方法大全(包含search_as_you_type等6种解法)
人工智能·深度学习·算法·elasticsearch·搜索引擎
她说彩礼65万2 小时前
C语言 函数指针
c语言·开发语言·算法
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:纪念品分组
c++·算法·贪心·csp·信奥赛·排序贪心·纪念品分组
贾斯汀玛尔斯2 小时前
每天学一个算法--贪心算法(Greedy Algorithm)
算法·贪心算法
前端摸鱼匠2 小时前
【AI大模型春招面试题24】什么是“注意力分数”?如何计算?其大小反映了什么?
人工智能·算法·ai·面试·大模型·求职招聘
MicroTech20252 小时前
融合残差结构的量子电路算法:MLGO微算法科技拓展量子机器学习频谱边界
科技·算法·机器学习
H_BB2 小时前
动态规划详解
c++·算法·动态规划