当前位置: 首页 > article >正文

[java基础-集合篇]优先队列PriorityQueue结构与源码解析

优先队列PriorityQueue

优先级队列表示为平衡二进制堆

queue[n] 的两个子级是 queue[2*n+1] 和 queue[2*(n+1)]。

注:左子节点index=2*parentIndex+1,右子节点index=2*parentIndex+2,源码中计算parent位置时就是这样反过来计算的

优先级队列按 comparator 排序,如果 comparator 为 null,则按元素的自然排序排序:对于堆中的每个节点 n 和 n 的每个后代 d,n

PriorityQueue 是一个基于优先级堆的无界优先级队列实现,它可以确保每次出队的元素都是队列中优先级最高(最小的)的元素。

PriorityQueue结构

PriorityQueue结构上是一个基于数组的“完全二叉树”,且“任意节点的值<=子节点的值”,是一个“小顶堆”。

完全二叉树:除最底层节点,其他层都是满的,并且最后一层的所有节点尽可能地靠左排列

PriorityQueue方法

add(E e)

实质是offer(E e)方法,元素首先被添加到数组末尾,然后通过siftUp方法向上调整位置以维持堆的性质

扩容grow(int minCapacity)

peek

取第一个元素

poll

取出第一个元素并删除。移除队列头部元素(即最小元素)时,会将数组最后一个元素移动到头部,然后通过siftDown方法向下调整位置以恢复堆的性质

两个方法和上浮方法一样,只是比较方式不同

PriorityQueue特点

不允许元素为null,无添加顺序(不会按照添加顺序来),自然顺序,线程不安全

使用位移运算代替乘除、提升运算效率。

PriorityQueue资料引用(推荐)

Java【优先级队列】详细图解 / 模拟实现 + 【PriorityQueue】常用方法介绍_java优先队列-CSDN博客


http://www.kler.cn/a/487902.html

相关文章:

  • imageio 图片转mp4 保存mp4
  • HTML5 动画效果:淡入淡出(Fade In/Out)详解
  • docker minio镜像arm64架构
  • 微服务拆分的艺术:构建高效、灵活的系统架构
  • 【年前假期学SHU分享】:计算机生物学、智能计算、通信、大数据、电子信息工程
  • Springboot SAP Docker 镜像打包问题
  • 【JavaEE】—— SpringBoot项目集成百度千帆AI大模型(对话Chat V2)
  • SpringCloud系列教程:微服务的未来(十一)服务注册、服务发现、OpenFeign快速入门
  • Web基础之什么是HTTP协议
  • JavaSE——网络编程
  • Python基于YOLOv8和OpenCV实现车道线和车辆检测
  • 有机物谱图信息的速查技巧有哪些?
  • 【2025最新计算机毕业设计】基于SpringBoot+Vue奶茶点单系统(高质量源码,提供文档,免费部署到本地)
  • vue3+element-plus暗黑模式切换动画圆弧过渡
  • linux nginx 安装后,发现SSL模块未安装,如何处理?
  • Mumu模拟器和Frida
  • 【读点论文】DepGraph: Towards Any Structural Pruning通用的结构化剪枝框架,处理结构化剪枝的图依赖问题
  • 20250109使用M6000显卡在Ubuntu20.04.6下跑whisper来识别中英文字幕
  • Vue 2 提取可复用 Footer 组件
  • L1G5000 XTuner 微调个人小助手认知
  • 【Vue.js 组件化】高效组件管理与自动化实践指南
  • vs2022开发.net窗体应用开发环境安装配置以及程序发布详细教程
  • STM32 : PWM 基本结构
  • [network]回顾:集线器(Hub)
  • poi-tl+kkviewfile实现生成pdf业务报告
  • 深入Android架构(从线程到AIDL)_21 IPC的Proxy-Stub设计模式03