Java中堆的使用--PriorityQueue


前言

堆是一个不太容易理解的数据结构,它的本质是二叉树,但是课本中通常以数组的形式呈现。某一节点(i)的左子节点为2i,右子节点为,2i+1。
JDK中自带了一个PriorityQueue,实际上就是一个堆。

一、小顶堆怎么实现?

默认的PriorityQueue就是一个小顶堆,实例化、插入、弹出、查看堆顶元素的操作如下:

PriorityQueue<Integer> minHeap = new PriorityQueue<>();
minHeap.offer(1);//插入
minHeap.poll();//弹出堆顶
minHeap.peek();//查看堆顶

二、大顶堆怎么实现?

大顶堆只需要改变PriorityQueue的排序策略。

PriorityQueue<Integer> maxHeap = new PriorityQueue<Integer>((e1,e2)->(e2-e1));
maxHeap.offer(3);
maxHeap.offer(4);
System.out.println(maxHeap.peek());//返回4
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值