JavaScript 数据结构(四):双端队列

JavaScript 数据结构系列目录

JavaScript 数据结构(一): 数组

JavaScript 数据结构(二): 栈

JavaScript 数据结构(三):队列

JavaScript 数据结构(四):双端队列

JavaScript 数据结构(五):链表

JavaScript 数据结构(六):集合

JavaScript 数据结构(七):字典

JavaScript 数据结构(八):散列表

JavaScript 数据结构(九):树

JavaScript 数据结构(十):二叉堆和堆排序

JavaScript 数据结构(十一):图



一、双端队列的概述

什么是双端队列(Double-ended queue)

双端队列是一种允许我们同时从顶部和底部添加和移除的特殊队列。

而其在现实生活中的例子有餐厅排队等。如,一个刚买了票的人离开了,离开后突然有点问题想要咨询,就可以直接回到队伍的头部。同样的,如果尾部的人赶时间,他可以直接离开队伍。

二、创建一个双端队列类

和之前一样,我们先声明一个 Deque 类及其构造函数

class Deque {
   
    constructor() {
   
        this.count = 0;
        this.lowestCount = 0;
        this.items = {
   };
    }
}

既然双端队列是一种特殊队列,我们可以看到其构造函数中的部分代码和队列相同,包括相同内部属性和以下方法:isEmpty、clear、size 和 toString。

由于双端队列允许在两端添加和移除元素,所以还会有下面几个方法。

  1. addFront(element) : 该方法在双端队列的底部添加新的元素。
  2. addBack(element) : 该方法等同于 Queue 类中的 enqueue 方法。
  3. removeFront() : 该方法等同于 Queue 类中的 dequeue 方法。
  4. removeBack() : 该方法等同于 Stack 类中的 pop 方法。
  5. seeFrontTop : 该方法等同于 Queue 类中的 seeTop 方法。
  6. seeBackTop : 该方法等同于 Stack 类中的 seeTop 方法。

由于已经实现了部分方法,所以我们将只专注于 addFront 方法的逻辑。

其代码如下:

addFront(element) 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值