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;}
}


总结

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

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...