news 2026/4/18 12:39:30

java基础-PriorityQueue(优先队列)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
java基础-PriorityQueue(优先队列)

1. 基本概念

PriorityQueue 是 Java 集合框架中的一个基于优先堆的无界队列。它使用优先顺序(通常是元素的自然顺序或自定义比较器)来管理元素,而不是标准的 FIFO(先进先出)顺序。

// 基本创建方式 PriorityQueue<Integer> pq = new PriorityQueue<>(); // 最小堆(默认) PriorityQueue<Integer> pqMax = new PriorityQueue<>(Collections.reverseOrder()); // 最大堆

2. 核心特性

特性说明
排序方式元素按优先级排序,队头总是优先级最高的元素
数据结构基于二叉堆实现(默认最小堆)
线程安全不是线程安全的(如需线程安全用PriorityBlockingQueue
null元素❌ 不允许插入 null
时间复杂度插入/删除:O(log n),获取队头:O(1)

3. 常用操作示例

import java.util.PriorityQueue; public class PriorityQueueDemo { public static void main(String[] args) { // 1. 创建最小堆(默认) PriorityQueue<Integer> minHeap = new PriorityQueue<>(); // 添加元素 minHeap.offer(5); minHeap.offer(1); minHeap.offer(3); minHeap.offer(2); System.out.println("最小堆元素顺序:"); while (!minHeap.isEmpty()) { System.out.print(minHeap.poll() + " "); // 输出: 1 2 3 5 } // 2. 创建最大堆 PriorityQueue<Integer> maxHeap = new PriorityQueue<>((a, b) -> b - a); // 自定义比较器 maxHeap.offer(5); maxHeap.offer(1); maxHeap.offer(3); System.out.println("\n最大堆元素顺序:"); while (!maxHeap.isEmpty()) { System.out.print(maxHeap.poll() + " "); // 输出: 5 3 1 } // 3. 自定义对象排序 PriorityQueue<Student> studentQueue = new PriorityQueue<>( (s1, s2) -> s1.score - s2.score // 按分数升序 ); } } class Student { String name; int score; // 构造方法等... }

4. 底层实现原理

// 简化版内部结构理解 public class PriorityQueue<E> { private Object[] queue; // 存储元素的数组(二叉堆) private Comparator<? super E> comparator; // 添加元素时的上浮操作(heapify-up) // 删除元素时的下沉操作(heapify-down) }
  • 默认最小堆:父节点 ≤ 子节点

  • 存储结构:数组实现的完全二叉树

  • 父子节点关系

    • 父节点索引:(i-1)/2

    • 左子节点:2*i + 1

    • 右子节点:2*i + 2

5. 典型应用场景

// 场景1:Top K 问题(找出最大的K个元素) public List<Integer> topK(int[] nums, int k) { PriorityQueue<Integer> minHeap = new PriorityQueue<>(); for (int num : nums) { minHeap.offer(num); if (minHeap.size() > k) { minHeap.poll(); // 移除最小的,保持K个最大的 } } return new ArrayList<>(minHeap); } // 场景2:合并多个有序列表 public ListNode mergeKLists(ListNode[] lists) { PriorityQueue<ListNode> pq = new PriorityQueue<>( (a, b) -> a.val - b.val ); // 将每个链表的头节点加入队列 // 每次弹出最小的,加入其下一个节点 } // 场景3:任务调度(按优先级执行) PriorityQueue<Task> taskQueue = new PriorityQueue<>( Comparator.comparingInt(Task::getPriority) );

6. 注意事项

// ⚠️ 注意1:遍历时不保证顺序 PriorityQueue<Integer> pq = new PriorityQueue<>(); pq.add(3); pq.add(1); pq.add(2); System.out.println(pq); // 可能输出 [1, 3, 2] // 只有 poll() 或 peek() 才能看到正确顺序 // ⚠️ 注意2:不能插入不可比较对象 // PriorityQueue<Object> pq = new PriorityQueue<>(); // pq.add(new Object()); // 运行时错误:ClassCastException // ✅ 解决方案:提供Comparator PriorityQueue<Map.Entry<String, Integer>> pq = new PriorityQueue<>( Map.Entry.comparingByValue() );

7. 与相关类的比较

排序方式线程安全边界
PriorityQueue优先级顺序❌ 不安全无界
ArrayDequeFIFO/LIFO❌ 不安全无界
LinkedList插入顺序❌ 不安全无界
PriorityBlockingQueue优先级顺序✅ 安全无界

总结

  • PriorityQueue适合需要动态排序且频繁访问最小/最大元素的场景

  • 默认是最小堆,可通过 Comparator 改为最大堆或其他排序规则

  • 算法题中解决堆相关问题的常用工具(如 Top K、合并K个有序列表等)

  • 注意其非线程安全特性,多线程环境下需要使用PriorityBlockingQueue

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 7:26:32

运维转行网络安全,零基础入门到精通,看这一篇就够了!

运维怎么转行网络安全&#xff1f;零基础入门到精通&#xff0c;收藏这篇就够了 经常有人问我&#xff1a;干网工、干运维多年遇瓶颈&#xff0c;想学点新技术给自己涨涨“身价”&#xff0c;应该怎么选择&#xff1f; 聪明人早已经用脚投票&#xff1a;近年来&#xff0c;越…

作者头像 李华
网站建设 2026/4/17 17:55:48

13、JSTL 响应重定向与配置设置详解

JSTL 响应重定向与配置设置详解 1. JSTL 响应重定向 在基于 Java 的 Web 应用中,在 JSTL 出现之前,重定向 HTTP 响应的唯一方法是使用 HttpServletResponse.sendRedirect 方法。而 JSTL 通过 <c:redirect> 动作让重定向 HTTP 响应变得更加容易。 有一个应用示例…

作者头像 李华
网站建设 2026/4/18 7:56:13

2025项目管理软件怎么选?十大热门工具深度评测,避坑指南来了

无论是中小型团队的轻量协作&#xff0c;还是大型企业的复杂项目管控&#xff0c;选择合适的工具能让管理效率翻倍。精选10款好用的项目管理软件&#xff0c;从核心功能、适用场景到优劣势进行深度解析&#xff1a;进度猫 核心定位&#xff1a;国内领先的轻量级可视化项目管理工…

作者头像 李华
网站建设 2026/4/18 7:03:52

SpringBoot4.0合 Scala/Java 混编?我踩过的坑,请你绕行

SpringBoot4.0合 Scala/Java 混编&#xff1f;我踩过的坑&#xff0c;请你绕行 本节说明一下Scala和Java混合开发时&#xff0c;本地运行没问题&#xff0c;只要上线部署打成Jar包就会找不到启动类&#xff0c;启动时就会报错 1. 需要配置两个东西 1. Scala的依赖2. Scala的打…

作者头像 李华
网站建设 2026/4/15 20:01:04

WebUploader支持国密加密的大文件分块上传方案?

前端老哥的外包求生记&#xff1a;20G大文件上传系统&#xff08;Vue3原生JS&#xff09; 兄弟们&#xff01;我是福建一名“头发渐少但代码不秃”的前端程序员&#xff0c;最近接了个外包活——给客户做文件管理系统&#xff0c;核心需求就一个&#xff1a;“20G大文件文件夹…

作者头像 李华
网站建设 2026/4/15 1:20:24

提高表达能力必看的七本演讲与口才类书籍推荐

古语有云&#xff1a;「三寸之舌&#xff0c;强于百万之师」&#xff0c;足见口才的力量。TED掌门人克里斯也曾说&#xff1a;无论今天公众演讲有多重要&#xff0c;未来只会更重要&#xff01;为了帮助大家提升演讲与口才能力&#xff0c;特此推荐七本演讲方面的经典书籍&…

作者头像 李华