Java队列和优先队列

一、队列

1、队列是一个接口,不能直接new!

java.util接口 Queue<E>

类型参数:E - collection 中所保存元素的类型。

 

除了基本的 Collection 操作外,队列还提供其他的插入、提取和检查操作。每个方法都存在两种形式:一种抛出异常(操作失败时),另一种返回一个特殊值(null 或 false,具体取决于操作)。插入操作的后一种形式是用于专门为有容量限制的 Queue 实现设计的;在大多数实现中,插入操作不会失败。

 抛出异常返回特殊值
插入add(e)offer(e)
移除remove()poll()
检查element()peek()

 

队列的 都是调用 remove()poll() 所移除的元素。在 FIFO 队列中,所有的新元素都插入队列的末尾。其他种类的队列可能使用不同的元素放置规则。每个 Queue 实现必须指定其顺序属性。 

 booleanadd(E e)
          将指定的元素插入此队列(如果立即可行且不会违反容量限制),在成功时返回 true,如果当前没有可用的空间,则抛出 IllegalStateException。
 Eelement()
          获取,但是不移除此队列的头。
 booleanoffer(E e)
          将指定的元素插入此队列(如果立即可行且不会违反容量限制),当使用有容量限制的队列时,此方法通常要优于 add(E),后者可能无法插入元素,而只是抛出一个异常。
 Epeek()
          获取但不移除此队列的头;如果此队列为空,则返回 null。
 Epoll()
          获取并移除此队列的头,如果此队列为空,则返回 null。
 Eremove()
          获取并移除此队列的头。

2.常见的创建Queue的方法:

import java.util.LinkedList;

Queue<Integer> queue = new LinkedList<>();

3.学会运用队列的规律,FIFL

 

二、优先级队列

java.util类 PriorityQueue<E>

 一、  一个基于优先级堆的无界优先级队列。优先级队列的元素按照其自然顺序进行排序,或者根据构造队列时提供的 Comparator 进行排序,具体取决于所使用的构造方法。

 (默认小顶堆)此队列的 是按指定排序方式确定的最小 元素。如果多个元素都是最小值,则头是其中一个元素——选择方法是任意的。队列获取操作 pollremovepeekelement 访问处于队列头的元素。

   优先级队列是无界的,但是有一个内部容量,控制着用于存储队列元素的数组大小。它通常至少等于队列的大小。随着不断向优先级队列添加元素,其容量会自动增加。

如果需要按顺序遍历,请考虑使用 Arrays.sort(pq.toArray())

实现注意事项:此实现为排队和出队方法(offer、poll、remove() 和 add)提供 O(log(n)) 时间;为 remove(Object) 和 contains(Object) 方法提供线性时间;为获取方法(peek、element 和 size)提供固定时间。

PriorityQueue()
          使用默认的初始容量(11)创建一个 PriorityQueue,并根据其自然顺序对元素进行排序。
PriorityQueue(int initialCapacity)
          使用指定的初始容量创建一个 PriorityQueue,并根据其自然顺序对元素进行排序。

二、创建:

import java.util.PriorityQueue;

PriorityQueue<Integer> pq = new PriorityQueue<>();

三、优先级队列是正常入、按优先级出的队列,默认小顶堆。

end.

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值