双向队列Deque和单向队列Queue

做题时候反复需要使用队列,栈等数据结构,开个帖子记录一下如何使用。Stack官方已经建议淘汰不用,使用Deque来实现栈。
在这里插入图片描述
从图中可以很明显看到,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。

接口包含的方法:
在这里插入图片描述

Queue

Java中PriorityQueue通过二叉小顶堆实现,可以用一棵完全二叉树表示。
在这里插入图片描述
默认升序排列,如果要实现降序排列。可以使用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))

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值