java中的队列 单项队列 双向队列,双向队列Deque和单向队列Queue

做题时候反复需要使用队列,栈等数据结构,开个帖子记录一下如何使用。Stack官方已经建议淘汰不用,使用Deque来实现栈。

20fa13015f61cfbc02202467b80a5e0a.png

从图中可以很明显看到,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。

接口包含的方法:

e8bb8f8108c9f267664f6f724a6e058a.png

Queue

Java中PriorityQueue通过二叉小顶堆实现,可以用一棵完全二叉树表示。

48aa92d79d409a564d0a9ccd16b6a8c7.png

默认升序排列,如果要实现降序排列。可以使用lamda表达式来重写comparator。

//自定义比较器,降序排列

Queue qq = new PriorityQueue<>(new Comparator() {

public int compare(Integer e1, Integer e2) {

return e2 - e1;//异号降序

}

});

//自定义比较器,降序排列

Queue qq = new PriorityQueue<>((x,y)->(y,x));//lamda表达式实现降序

复杂度:

因为都是基于堆(二叉树的操作)

get时间复杂度:O(log(N))

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值