java-Queue-Deque

支持元素插入和移除的两端线性集合。
deque是“双端队列”的简称,大多数{@code Deque}实现对元素数量没有限制
但是此接口支持容量限制,

定义了访问元素的方法
提供提供了插入、删除和检查元素。
方法每一种都存在两种形式:
1.如果操作失败,抛出异常
2.返回特殊值 null或者false 取决于操作
插入操作的后一种形式是专为限制容量设计的
大多数实现中,插入操作不能失败
这里写图片描述

Deque实现Queue接口 可以当做FIFO
元素被加载deque末尾 被移除从开头移除
继承Queue接口 等价于Deque方法 如下表:
这里写图片描述

Deques 也能当做LIFO Last-In-First-Out 栈
接口应当优先使用{@link Stack} 类
当一个Deque被用作stack 元素被pushed和poped从Queue开始
Stack方法等价于Deque方法 如下表所示:
这里写图片描述

{@link #peek peek} 方法同样适用于当一个队列用作queue或者statck
,在任何情况下,元素都是从deque中开始的

此接口提供两种方法来移除内部元素, {@link #removeFirstOccurrence removeFirstOccurrence}
{@link #removeLastOccurrence removeLastOccurrence}.

与 {@link List}接口不同,此接口不为元素的索引访问提供支持。

{@code Deque}实现不是严格要求禁止插入null值,只是强烈鼓励。
任何{@code Deque} 实现允许null元素,但是不鼓励
因为 {@code null} 被用作特殊的返回值 标识deque是空的

@code Deque} 一般不实现基于元素的版本 {@code equals} and {@code hashCode}方法
但是继承类的基于身份的版本 来自 {@code Object}.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的QueueDeque是两种不同的数据结构。 1. Queue(单向队列)是一种FIFO(先进先出)的数据结构,它继承自Collection接口。Queue有一个直接子类PriorityQueue,它是一个基于优先级的队列,元素按照优先级进行排序。Queue的常用方法包括add()、offer()、remove()、poll()、element()和peek()等。 2. Deque(双向队列)是一种支持在两端添加或移除元素的数据结构,它继承自Queue接口。Deque有两个直接子类:LinkedList和ArrayDeque。LinkedList是基于链表实现的双向队列,而ArrayDeque是基于数组实现的双向队列。Deque的常用方法包括addFirst()、addLast()、offerFirst()、offerLast()、removeFirst()、removeLast()、pollFirst()、pollLast()、getFirst()、getLast()、peekFirst()和peekLast()等。 以下是Java中使用QueueDeque的示例代码: ```java import java.util.Queue; import java.util.LinkedList; import java.util.ArrayDeque; public class QueueDequeExample { public static void main(String[] args) { // 使用Queue Queue<String> queue = new LinkedList<>(); queue.add("apple"); queue.add("banana"); queue.add("orange"); System.out.println("Queue: " + queue); System.out.println("First element: " + queue.peek()); System.out.println("Removed element: " + queue.poll()); System.out.println("Queue after removal: " + queue); // 使用Deque Deque<Integer> deque = new ArrayDeque<>(); deque.addFirst(1); deque.addLast(2); deque.addLast(3); System.out.println("Deque: " + deque); System.out.println("First element: " + deque.getFirst()); System.out.println("Last element: " + deque.getLast()); System.out.println("Removed first element: " + deque.removeFirst()); System.out.println("Deque after removal: " + deque); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值