Java数据结构-优先级队列

Java中的优先级队列(Priority Queue)是Java集合框架的一部分,它实现了Queue接口,并允许存储的元素具有一定的优先级。优先级队列是自然排序的,或者根据创建优先级队列时提供的Comparator进行排序。这意味着队列的头部是优先级最高的元素。如果多个元素具有相同的优先级,则它们按照它们在队列中的顺序排序。

在Java中,优先级队列通常通过PriorityQueue类实现。以下是一个简单的示例:

java 复制代码
import java.util.PriorityQueue;

public class PriorityQueueExample {
    public static void main(String[] args) {
        // 创建一个优先级队列
        PriorityQueue<Integer> pq = new PriorityQueue<>();

        // 添加元素到优先级队列
        pq.add(3);
        pq.add(1);
        pq.add(4);
        pq.add(1);
        pq.add(5);
        pq.add(9);
        pq.add(2);
        pq.add(6);

        // 打印优先级队列的元素
        while (!pq.isEmpty()) {
            System.out.println(pq.poll());
        }
    }
}

在上面的示例中,我们创建了一个PriorityQueue对象,并添加了一些整数。由于PriorityQueue默认使用自然排序(对于整数,就是从小到大的顺序),因此当我们打印队列的元素时,它们将按照从小到大的顺序打印。

你也可以通过提供一个自定义的Comparator来改变排序规则。例如,如果你想要一个优先级队列,其中元素按照从大到小的顺序排列,你可以这样做:

java 复制代码
import java.util.Comparator;
import java.util.PriorityQueue;

public class PriorityQueueExample {
    public static void main(String[] args) {
        // 创建一个优先级队列,并使用自定义的Comparator
        PriorityQueue<Integer> pq = new PriorityQueue<>(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o2 - o1; // 降序排列
            }
        });

        // 添加元素到优先级队列
        pq.add(3);
        pq.add(1);
        pq.add(4);
        pq.add(1);
        pq.add(5);
        pq.add(9);
        pq.add(2);
        pq.add(6);

        // 打印优先级队列的元素
        while (!pq.isEmpty()) {
            System.out.println(pq.poll());
        }
    }
}

在这个例子中,我们创建了一个PriorityQueue对象,并提供了一个自定义的Comparator。这个Comparator将元素按照从大到小的顺序排列。因此,当我们打印队列的元素时,它们将按照从大到小的顺序打印。

相关推荐
I_LPL1 分钟前
day21 代码随想录算法训练营 二叉树专题8
算法·二叉树·递归
雨中飘荡的记忆2 分钟前
千万级数据秒级对账!银行日终批处理对账系统从理论到实战
java
jbtianci7 分钟前
Spring Boot管理用户数据
java·spring boot·后端
可编程芯片开发8 分钟前
基于PSO粒子群优化PI控制器的无刷直流电机最优控制系统simulink建模与仿真
人工智能·算法·simulink·pso·pi控制器·pso-pi
cpp_25019 分钟前
P8448 [LSOT-1] 暴龙的土豆
数据结构·c++·算法·题解·洛谷
lcj251110 分钟前
深入理解指针(4):qsort 函数 & 通过冒泡排序实现
c语言·数据结构·算法
Sylvia-girl10 分钟前
线程池~~
java·开发语言
fie888911 分钟前
基于MATLAB的转子动力学建模与仿真实现(含碰摩、不平衡激励)
开发语言·算法·matlab
魔力军14 分钟前
Rust学习Day3: 3个小demo实现
java·学习·rust
唐梓航-求职中18 分钟前
编程大师-技术-算法-leetcode-1472. 设计浏览器历史记录
算法·leetcode