四.队列与双端队列

1.队列概述

  • 队列(queue)是一种是相对于栈的一种数据结构,它是先进先出(First In First Out)。
    它只可以在尾部添加元素。
    队列
  • 双端队列(deque double ended queue(双端队列))是一种相对于队列的一种数据结构。它可以在尾部和头部插入、移除和获取。
    双端队列

2.队列方法

  • java.util.Queue接口,用以支持队列的常见操作。该接口扩展了java.util.Collection接口。
方法抛出异常返回值
插入add()offer()
删除remove()poll()
查询element()peek()
  • java.util.Deque接口,用以支持双端队列的常见操作。该接口扩展了java.util.Queue接口。
方法头部抛出异常尾部抛出异常头部返回值尾部返回值
插入addFirst()offerFirst()addLast()offerLast()
删除removeFirst()pollFirst()removeLast()pollLast()
查询getFirst()peekFirst()getLast()peekLast()
  • LinkedList是一个继承于AbstractSequentialList的双向链表。
    使用LinkedList实现Queue接口来表示队列。
    使用LinkedList实现Deque接口来表示双向队列。
  • Queuequeue=newLinkedList();
  • Deque deque = new LinkedList();

3.有意思的例子

  • 怎样用栈来实现一个队列?
    答:使用两个栈A和B,A栈将数据正常进栈,然后出栈进入B栈,从B栈出来的数据就是队列的数据。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值