9.Java中PriorityQueue详解及堆相关的算法题

本文详细介绍了Java中的PriorityQueue,它基于二叉小顶堆实现,作为优先队列保证每次取出最小元素。文章讨论了如何利用PriorityQueue解决数组中的第K个最大元素和找出前K个高频单词的问题,提供了排序和堆两种算法思路,分析了它们的时间复杂度。
摘要由CSDN通过智能技术生成

Java中PriorityQueue详解

Java中PriorityQueue通过二叉小顶堆实现,可以用一棵完全二叉树表示。PriorityQueue其实是一种特殊的队列,即优先队列。优先队列的作用是能保证每次取出的元素都是队列中权值最小的(Java的优先队列每次取最小元素)。这里牵涉到了大小关系,元素大小的评判可以通过元素本身的自然顺序(natural ordering),也可以通过构造时传入的比较器(Comparator,类似于C++的仿函数)。

Java中PriorityQueue实现了Queue接口,不允许放入null元素;其通过堆实现,具体说是通过完全二叉树(complete binary tree)实现的小顶堆(任意一个非叶子节点的权值,都不大于其左右子节点的权值),也就意味着可以通过数组来作为PriorityQueue的底层实现。

二、常用方法

peek()//返回队首元素
poll()//返回队首元素,队首元素出队列
add()//添加元素
size()//返回队列元素个数
isEmpty()//判断队列是否为空,为空返回true,不空返回false
offer(E e) //offer()方法用于将给定元素(e)添加到此PriorityQueue中。 
new PriorityQueue();//默认构造函数,构建一个小顶堆
new PriorityQueue(Comparator.reverseOrder());//构建一个大顶堆

算法题215: 数组中的第K个最大元素

在未排序的数组中找到第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

示例 1:

输入: [3,2,1,5,6,4] 和 k = 2
输出: 5

示例 2:

输入: [3,2,3,1,2,4,5,5,6] 和 k = 4
输出: 4

说明:

你可以假设 k 总是有效的,且 1 ≤ k ≤ 数组的长度。

思路:利用PriorityQueue构建一个大顶堆,则堆顶的永远是最大的。将前k-1个数移出,第k个数就是数组中第 k 个最大的元素。

public int findKthLargest(int[] nums, int k) {
   
    PriorityQueue<Integer> priorityQueue =
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值