算法与数据结构随笔-生活工作点滴

算法与数据结构系列之[优先队列]

2019-07-10  本文已影响9人  秦老厮

前面我们介绍了队列这种数据结构,不过我们在前面所介绍的队列只是一种普通的队列,即元素先进先出,其实队列还可以分优先级,优先级高的元素先出,比如操作系统的调度,会将优先级高的任务先调度执行,这种队列就叫做优先队列。

那么优先队列底层该如何实现呢?

1.优先队列可以使用普通的线性结构,比如动态数组,入队时的时间复杂度为O(1),出队时需要遍历元素,找到优先级最大的元素出队,时间复杂度为O(n)。

2.使用顺序线性结构,入队时需要按优先级大小排序存储,所以时间复杂度为O(n),出队时只需要按优先级大小出队即可,时间负责度为O(1)。

3.使用堆这种数据结构,其入队和出队的时间复杂度都为O(logn)。数据量大时,这种使用堆这种数据结构非常高效。

优先队列的java代码实现(这里用最大堆,jdk的优先队列是用最小堆实现的):

public class PriorityQueue<E extends Comparable<E>> implements Queue<E> {

   private MaxHeap<E> maxHeap;  //用最大堆实现

   public PriorityQueue(){
       maxHeap = new MaxHeap<>();
   }

   @Override
   public int getSize() {
       return maxHeap.getSize();
   }

   @Override
   public boolean isEmpty() {
       return maxHeap.isEmpty();
   }

   @Override
   public void enqueue(E e) {
       maxHeap.add(e);
   }

   @Override
   public E dequeue() {
       return maxHeap.extractMax();
   }

   @Override
   public E getFront() {
       return maxHeap.findMax();
   }
}

上一篇下一篇

猜你喜欢

热点阅读