双向队列Deque和单向队列Queue

做题时候反复需要使用队列,栈等数据结构,开个帖子记录一下如何使用。Stack官方已经建议淘汰不用,使用Deque来实现栈。
双向队列Deque和单向队列Queue_第1张图片
从图中可以很明显看到,collection集合类有三个继承者,Set,List,Queue
。而Deque和PriorityQueue(堆,优先队列)是继承自Queue。Deque是双端队列,而LinkedList是双端链表,所以Deque在频繁进行增删的时候,可以使用LinkedList来实现接口。

Deque

ArrayDeque与LinkList区别:

ArrayDeque:
1、循环数组实现
2、插入元素不能为null
3、无法确定数据量时,后期扩容会影响效率
4、复杂度:add时间复杂度:O(n); remove时间复杂度:O(n) ; get时间复杂度:O(1)

LinkedList:
1、双向链表 实现
2、插入元素能为null
3、无法确定数据量时,有更好表现
4、add时间复杂度:O(1); remove时间复杂度:O(1); get时间复杂度:O(n)

在频繁进行增删时候选择LinkedList,在频繁进行查找时候选择ArrayDeque。

接口包含的方法:
双向队列Deque和单向队列Queue_第2张图片

Queue

Java中PriorityQueue通过二叉小顶堆实现,可以用一棵完全二叉树表示。
双向队列Deque和单向队列Queue_第3张图片
默认升序排列,如果要实现降序排列。可以使用lamda表达式来重写comparator。

//自定义比较器,降序排列
     Queue<Integer> qq = new PriorityQueue<>(new Comparator<Integer>() {
      public int compare(Integer e1, Integer e2) {
        return e2 - e1;//异号降序
      }
    });
//自定义比较器,降序排列
 Queue<Integer> qq = new PriorityQueue<>((x,y)->(y,x));//lamda表达式实现降序

复杂度:
因为都是基于堆(二叉树的操作)
get时间复杂度:O(log(N))

add/offer时间复杂度:O(log(N))

remove/poll时间复杂度:O(log(N))

你可能感兴趣的:(数据结构,java,queue)