android Deque双端队列,Queue先进先出队列常用方法介绍

本文详细比较了Java中的Deque和Queue数据结构,重点介绍了Duque支持两端插入和移除的特点,以及它们各自的添加、移除、查看等方法的使用和行为差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Duque和Queue的区别就在于:Duque是两端可以进出的,Queue只能先进先出。

Deque插入移除方法介绍

dequed队列支持两端的因素插入和移除,

add(E e)

将指定元素插入队列尾部,如果它是立即可行不会违反容量限制,返回成功,如果当前没有空间可用抛出异常IllegalStateException

offer(E e)

将指定元素插入队列尾部,如果它是立即可行不会违反容量限制,返回成功true,如果当前没有空间可用返回false

addFirst(E e)

向队列头部添加元素,有空间true,没有空间抛异常

addLast(E e)

向队列尾部添加元素,有空间true,没有空间抛异常

offerFirst(E e)

向队列头部添加元素,有空间true,没有空间false

offerLast(E e)

向队列尾部添加元素,有空间true,没有空间false

contains(Object o)

队列是否包含指定元素

descendingIterator()

以相反顺序返回此双端队列中元素的迭代器

getFirst()

检索但不删除队列的第一个元素,如果是空抛异常

getLast()

检索但不删除队列的最后一个元素,如果是空抛异常

peek()

检索但不移除队列的第一个元素

peekLast()

检索但不移除队列的最后一个元素

poll()

检索并移除队里的头部元素,如果不存在返回null

pollFirst()

检索并移除队列的第一个元素

pollLast()

检索并移除队列的最后一个元素

pop()

从队列中移除第一个元素,如果是空抛异常

remove()

检索并移除此队列的第一个元素,如果是空抛异常

remove(Object o)

检索并移除此队列的指定元素

Qeque插入移除方法介绍

Queue的特性:先进先出

add(E e)

在队列尾部添加一个元素,如果超出容量,抛异常

offer(E e)

在队列尾部添加一个元素,如果超出容量false

poll()

移除一个队列头部元素,如果为空null

remove()

移除队列头部元素,如果为空抛异常

peek()

查看队列头部元素,不会移除,如果为空null

element()

查看队列头部元素,不会移除,如果为空抛异常

链接: https://www.xfqiao.com/api/android-zh/java/util/Deque.html

### C++ 双端队列 `deque` 使用方法 #### 创建与初始化 双端队列可以通过多种方式创建并初始化。最常见的方式是在声明时指定容器内元素的数据类型。 ```cpp #include <deque> using namespace std; // 定义一个整数类型的双端队列 deque<int> d; ``` 也可以通过初始化列表来定义初始值[^1]: ```cpp deque<int> d = {1, 2, 3}; ``` #### 基本操作函数 ##### 插入数据 可以在双端队列的两端插入新元素,分别使用 `push_front()` 或者 `push_back()` 方法向头部或尾部添加单个元素[^2]。 ```cpp d.push_front(0); d.push_back(4); ``` 同样支持批量插入多个相同数值的新项至任意一端: ```cpp fill_n(back_inserter(d), n, value); // 向后追加n个value fill_n(front_inserter(d), m, val); // 往前塞m个val ``` ##### 删除数据 移除首尾位置上的现有成员可通过调用相应的弹出命令完成——即 `pop_front()` 和 `pop_back()` 函数。 ```cpp if (!d.empty()) { d.pop_front(); } if (!d.empty()) { d.pop_back(); } ``` 注意,在执行这些删除动作之前应该先验证容器是否为空(`empty()`)以免发生越界错误。 #### 访问元素 为了获取特定索引处的内容而不改变其结构,则可利用下标运算符[]访问;另外还有专门用于读取第一个和最后一个条目的快捷属性:front() 和 back()。 ```cpp cout << "First element is: " << d.front() << endl; cout << "Last element is : " << d.back() << endl; for (size_t i = 0; i < d.size(); ++i){ cout<<d[i]<<" "; } ``` #### 排序功能 对于已经存在的双端队列实例来说,如果想要对其进行升序排列可以直接应用标准库中的sort算法,并传入迭代器范围作为参数传递给它即可实现默认从小到大的顺序排序。 ```cpp std::sort(d.begin(), d.end()); ``` 而降序则需额外提供比较谓词对象greater<>模板特化版: ```cpp std::sort(d.begin(), d.end(), std::greater<int>()); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值