当前位置:   article > 正文

【leetcode】前 K 个高频元素_前k个高频元素 给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前

前k个高频元素 给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前

题目:

给定一个非空的整数数组,返回其中出现频率前 高的元素。

示例 1:

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

示例 2:

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

说明:

  • 你可以假设给定的 总是合理的,且 1 ≤ k ≤ 数组中不相同的元素的个数。
  • 你的算法的时间复杂度必须优于 O(n log n) , 是数组的大小。

 

思路:

求频率最高的题目, 第一想法就是要用HashMap,key是每个数字,value是数字出现的次数。
求出每个数字的频率之后,我们想要求出第k高的频率的元素,并且时间复杂度必须优于O(nlog n),那么该如何求呢?
我们应该想到,堆的时间复杂度正好是O(nlog n),可以用堆来求。而堆是可以利用优先队列PriorityQueue来求的
重写compare方法,把频率最高的前k个数字加入queue中, 最后只要把优先队列中的值给弹出,然后再add到list中去就可以了。
 

java代码:

  1. class Solution {
  2. public List<Integer> topKFrequent(int[] nums, int k) {
  3. List<Integer> res = new ArrayList<>();
  4. if (nums == null || nums.length == 0) {
  5. return res;
  6. }
  7. Map<Integer, Integer> map = new HashMap();
  8. for (int i : nums) {
  9. if (!map.containsKey(i)) {
  10. map.put(i, 1);
  11. } else {
  12. map.put(i, map.get(i) + 1);
  13. }
  14. }
  15. PriorityQueue<Integer> queue = new PriorityQueue<>(new Comparator<Integer>() {
  16. @Override
  17. public int compare(Integer o1, Integer o2) {
  18. return map.get(o1) - map.get(o2);
  19. }
  20. });
  21. for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
  22. if (queue.size() < k) {
  23. queue.add(entry.getKey());
  24. } else {
  25. if (entry.getValue() > map.get(queue.peek())) {
  26. queue.remove();
  27. queue.add(entry.getKey());
  28. }
  29. }
  30. }
  31. while (!queue.isEmpty()) {
  32. res.add(queue.remove());
  33. }
  34. return res;
  35. }
  36. }

 

由于水平有限,博客中难免会有一些错误,有纰漏之处恳请各位大佬不吝赐教!

推荐阅读:

【leetcode-动态规划】爬楼梯  - CSDN博客

【leetcode-动态规划】买卖股票的最佳时机  - CSDN博客

【leetcode-动态规划】最大子序和 

【leetcode-动态规划】 不同路径  - CSDN博客

【leetcode-动态规划】打家劫舍  

 

及时更新最新文章和学习资料,一起来学习:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/685289
推荐阅读
相关标签
  

闽ICP备14008679号