mirror of
https://github.com/krahets/hello-algo.git
synced 2026-04-13 18:00:18 +08:00
build
This commit is contained in:
@@ -4,7 +4,7 @@ comments: true
|
||||
|
||||
# 5.3 双向队列
|
||||
|
||||
对于队列,我们仅能在头部删除或在尾部添加元素。然而,「双向队列 deque」提供了更高的灵活性,允许在头部和尾部执行元素的添加或删除操作。
|
||||
在队列中,我们仅能在头部删除或在尾部添加元素。如下图所示,「双向队列 deque」提供了更高的灵活性,允许在头部和尾部执行元素的添加或删除操作。
|
||||
|
||||

|
||||
|
||||
@@ -336,7 +336,7 @@ comments: true
|
||||
|
||||
对于双向队列而言,头部和尾部都可以执行入队和出队操作。换句话说,双向队列需要实现另一个对称方向的操作。为此,我们采用“双向链表”作为双向队列的底层数据结构。
|
||||
|
||||
我们将双向链表的头节点和尾节点视为双向队列的队首和队尾,同时实现在两端添加和删除节点的功能。
|
||||
如下图所示,我们将双向链表的头节点和尾节点视为双向队列的队首和队尾,同时实现在两端添加和删除节点的功能。
|
||||
|
||||
=== "LinkedListDeque"
|
||||

|
||||
@@ -355,7 +355,7 @@ comments: true
|
||||
|
||||
<p align="center"> 图:基于链表实现双向队列的入队出队操作 </p>
|
||||
|
||||
以下是具体实现代码。
|
||||
实现代码如下所示。
|
||||
|
||||
=== "Java"
|
||||
|
||||
@@ -1975,7 +1975,7 @@ comments: true
|
||||
|
||||
### 2. 基于数组的实现
|
||||
|
||||
与基于数组实现队列类似,我们也可以使用环形数组来实现双向队列。在队列的实现基础上,仅需增加“队首入队”和“队尾出队”的方法。
|
||||
如下图所示,与基于数组实现队列类似,我们也可以使用环形数组来实现双向队列。
|
||||
|
||||
=== "ArrayDeque"
|
||||

|
||||
@@ -1994,7 +1994,7 @@ comments: true
|
||||
|
||||
<p align="center"> 图:基于数组实现双向队列的入队出队操作 </p>
|
||||
|
||||
以下是具体实现代码。
|
||||
在队列的实现基础上,仅需增加“队首入队”和“队尾出队”的方法。
|
||||
|
||||
=== "Java"
|
||||
|
||||
|
||||
Reference in New Issue
Block a user