java~优先级队列PriorityQueue
概念
PriorityQueue是一种支持排序的优先级队列,你入队列的对象需要实现Comparable或Comparator接口,或者它本身支持自然排序,如Integer,Long这些类型(这些类型也都实现了Comparable接口
)。
数据结构
优先级队列底层的数据结构其实是一颗二叉堆,什么是二叉堆呢?我们来看看下面的图(a为大顶堆,b为小顶堆)
- 在这里我们会发现以下特征:
- 二叉堆是一个完全二叉树
- 根节点总是大于左右子节点(大顶堆),或者是小于左右子节点(小顶堆)。
java代码例子
- 定义一个对象,实现Comparable接口
@Data
static class Customer implements Comparable<Customer> {
private int id;
private String name;
public Customer(int i, String n) {
this.id = i;
this.name = n;
}
public int getId() {
return id;
}
public String getName() {
return name;
}
@Override
public int compareTo(Customer o) {
if (this.id < o.id) return -1; // 小于目标值,返回-1表示升序,即-1表示数值由小到大的排序
else if (this.id == o.id) return 0;
else return 1;
}
}
- 添加测试用例
@Test
public void test() {
Queue<Customer> priorityQueue = new PriorityQueue<>();
priorityQueue.add(new Customer(1, "zhansan"));
priorityQueue.add(new Customer(2, "lisi"));
priorityQueue.add(new Customer(4, "wangwu"));
while (!priorityQueue.isEmpty()) {
Customer cust = priorityQueue.poll();
System.out.println("Processing Customer =" + cust.toString());
}
}
- 测试结果,按着id的升序出队列
Processing Customer =PriorityQueueTest.Customer(id=1, name=zhansan)
Processing Customer =PriorityQueueTest.Customer(id=2, name=lisi)
Processing Customer =PriorityQueueTest.Customer(id=4, name=wangwu)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2019-10-09 springboot~yml里的自定义配置~续
2016-10-09 IoC组件~Autofac将多实现一次注入,根据别名Resove实例
2016-10-09 Redis集群~StackExchange.Redis(10月6号版1.1.608.0)连接Twemproxy支持Auth指令了
2014-10-09 缓存篇(Cache)~第三回 HttpModule实现网页的文件级缓存
2014-10-09 爱上MVC系列~带扩展名的路由失效问题
2014-10-09 开发人员应该对IIS理论层的知识了解的多一些~第四讲 HttpModule中的几大事件
2012-10-09 将不确定变为确定~头压缩是否有必要,MVC如何实现头压缩