leetcode:347. 前 K 个高频元素

在这里插入图片描述

import java.util.LinkedList;
import java.util.List;
import java.util.TreeMap;
class Solution {
   private class Freq implements Comparable<Freq> {
		int num;// 数的值
		int freq;// 数的次数

		public Freq(int num, int freq) {
			this.num = num;
			this.freq = freq;
		}

		@Override
		public int compareTo(Freq other) {
			// TODO Auto-generated method stub
			//始种保持堆顶出现的次数最少,最小堆。
			if(this.freq>other.freq) {//换
				return 1;//
			}else if(this.freq<other.freq) {//不换
				return -11;//
			}else {//不换
				return 0;
			}	
		}

	}

	public List<Integer> topKFrequent(int[] nums, int k) {
		//得到所有数字的频次
          TreeMap<Integer, Integer> map = new TreeMap<>();
          for (int i : nums) {
			if(map.containsKey(i)) {
				map.put(i,map.get(i)+1);
			}else {
				map.put(i, 1);
			}
		}
          //入队操作
          PriorityQueue<Freq> pq = new PriorityQueue<>();
          for (int key : map.keySet()) {
        	  if(pq.size()<k) {
        		  pq.add(new Freq(key, map.get(key)));
        	  }else if(map.get(key)>pq.peek().freq) {
        		  pq.remove();
        		  pq.add(new Freq(key,map.get(key)));
        	  }
		}
          LinkedList<Integer> list = new LinkedList<>();
          while(!pq.isEmpty()) {
        	  list.add(pq.remove().num);
          }
          return list;
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值