当前位置: 首页 > news >正文

前 K 个高频元素

前 K 个高频元素

​ 给你一个整数数组 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 个高频元素的集合是唯一的

题解:

​ 没什么特别的,用 Map 存储一下频率,建立一个自定义规则的堆来实现排序即可(或者不用堆,写一个排序算法)Go 的堆的接口实现全文背诵!

class Solution {public int[] topKFrequent(int[] nums, int k) {Map<Integer, Integer> map = new HashMap<Integer, Integer>();for (int i = 0; i < nums.length; i++) {if (map.containsKey(nums[i])) {map.put(nums[i], map.get(nums[i]) + 1);} else {map.put(nums[i], 1);}}PriorityQueue<Map.Entry<Integer, Integer>> heap = new PriorityQueue<>((e1, e2) -> e2.getValue() - e1.getValue());for (Map.Entry<Integer, Integer> entry : map.entrySet()) {heap.offer(entry);}int[] ans = new int[k];for (int i = 0; i < k; i++) {ans[i] = heap.poll().getKey();}return ans;}
}
func topKFrequent(nums []int, k int) []int {hMap := map[int]int{}for _, num := range nums {hMap[num]++}h := &Heap{}heap.Init(h)for key, value := range hMap {heap.Push(h, [2]int{key, value})}ans := make([]int, k)for i := 0; i < k; i++ {ans[i] = heap.Pop(h).([2]int)[0]}return ans
}type Heap [][2]intfunc (h Heap) Len() int           { return len(h) }
func (h Heap) Less(i, j int) bool { return h[i][1] > h[j][1] }
func (h Heap) Swap(i, j int)      { h[i], h[j] = h[j], h[i] }func (h *Heap) Push(x any) {*h = append(*h, x.([2]int))
}func (h *Heap) Pop() any {old := *hn := len(old)x := old[n-1]*h = old[0 : n-1]return x
}
http://www.lryc.cn/news/484065.html

相关文章:

  • 【ubuntu】Geogebra
  • vue2和vue3的区别详解
  • 一文读懂LEED绿建
  • git上feature合并到development分支
  • NVR录像机汇聚管理EasyNVR多品牌NVR管理工具/设备:大华IPC摄像头局域网访问异常解决办法
  • 校园二手交易网站毕业设计基于SpringBootSSM框架
  • 基于大语言模型意图识别和实体提取功能;具体ZK数值例子:加密货币交易验证;
  • 论文笔记 SuDORMRF:EFFICIENT NETWORKS FOR UNIVERSAL AUDIO SOURCE SEPARATION
  • 机器学习系列----KNN分类
  • 贪心算法day 06
  • HTML之列表学习记录
  • Redo与Undo的区别:数据库事务的恢复与撤销机制
  • 【话题讨论】AI赋能电商:创新应用与销售效率的双轮驱动
  • 重构开发之道,Blackbox.AI为技术注入智能新动力
  • 机器学习在医疗健康领域的应用
  • M芯片Mac构建Dockerfile - 注意事项
  • 系统架构设计师论文
  • 速盾:CDN 和高防有什么区别?
  • goframe开发一个企业网站 rabbitmq队例15
  • 设计模式-七个基本原则之一-迪米特法则 + 案例
  • 【数学二】线性代数-二次型
  • 320页PDF | 集团IT蓝图总体规划报告-德勤(限免下载)
  • HTB:Sea[WriteUP]
  • Java 网络编程(一)—— UDP数据报套接字编程
  • ECharts图表图例8
  • Redis中的线程模型
  • [产品管理-77]:技术人需要了解的常见概念:科学、技术、技能、产品、市场、商业模式、运营
  • 鼠标点击(一)与3D视口窗口的交互
  • 线程-2-线程概念与控制
  • TortoiseSVN提示服务器凭证检核错误:站点名称不符