JAVA练习79-前 K 个高频元素
创始人
2025-05-28 15:14:01
0

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

前言

一、题目-前 K 个高频元素

1.题目描述

2.思路域代码

2.1 思路

2.2 代码

总结


前言

提示:这里可以添加本文要记录的大概内容:

3月15日练习内容


提示:以下是本篇文章正文内容,下面案例可供参考

一、题目-前 K 个高频元素

1.题目描述

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

示例 1:

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

示例 2:

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

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/top-k-frequent-elements
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2.思路域代码

2.1 思路

1.创建hashmap集合,将数据放入集合中,并计算每个元素在集合中出现的次数

2.创建最大堆队列,将每个元素以及其出现次数放入最大堆中

3.创建输出数组,使用for循环将前k个数在最大堆中出队并赋值给输出数组

4.输出数组

2.2 代码

代码如下(示例):

class Solution {public int[] topKFrequent(int[] nums, int k) {//创建Map集合Map res = new HashMap<>();//统计每个for(int num : nums){res.put(num,res.getOrDefault(num,0) + 1);}//最大堆PriorityQueue pq = new PriorityQueue<>((a,b) ->b[1] - a[1]);for(int key : res.keySet()){pq.add(new int[] {key,res.get(key)});}//取堆中最大的k个元素int[] temp = new int[k];for(int i = 0;i < k;i ++){temp[i] = pq.poll()[0];}return temp;}
}


总结

提示:这里对文章进行总结:
 

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...