您现在的位置是:群英 > 开发技术 > web开发
JavaScript实现队列的操作是什么,有什么要注意的
Admin发表于 2022-09-03 17:55:18594 次浏览
在这篇文章中,我们将学习“JavaScript实现队列的操作是什么,有什么要注意的”的相关知识,下文有详细的介绍及示例,小编觉得挺不错的,有需要的朋友可以借鉴参考,希望对大家阅读完这篇能有所获。


1. 队列数据结构

  • 队列是一种“先入先出”(FIFO)数据结构的类型。第一个入队项目(输入)是第一个出队(输出)。
  • 队列有2个指针:头和尾。队列中的最早排队的项目是在头部,而最新排队的项目在队列尾部。
  • 队列就像我们在地铁排队,靠近车门处的乘客位于队伍的头部,刚进入队伍的乘客位于队伍的尾部。

从更高的角度来看,队列是一种数据结构,可以让我们按照入库的顺序依次处理数据的每一项。

2. 队列上的操作

队列支持2个主要操作:入队和出队。此外,您可能会发现执行队列的 peek 和 length 操作很有用。

  • 入队操作
    入队操作是在队列尾部插入一个项目,插入的项目成为队列的尾部。

上图中的入队操作将项目 8 插入到尾部,8成为队列的尾部。

queue.enqueue(8);
  • 出队操作
    出队操作是在队列的开头提取项目,队列中的下一个项目成为头部项目。

在上图中,出队操作返回并 7 从队列中删除该项目,出队后,项目2成为新的头部项目。

queue.dequeue(); // => 7
  • 检视操作
    检视操作读取队列的开头,而不会更改队列。

项目7是上图中的队列的开头,检视操作仅返回标头(项目)7,而无需修改队列。

queue.peek(); // => 7
  • 队列长度
    长度操作计算队列包含多少个项目。

图中的队列中有4项:4,6,2,和7,结果,队列长度为4。

queue.length; // => 4
  • 队列操作时间复杂度
    对于所有队列操作(入队,出队,检视和长度)重要的是,所有这些操作必须在固定时间内执行O(1)。

恒定的时间O(1)意味着无论队列大小如何(它可以有10或100万个项目):入队,出队,窥视和长度操作都必须同时执行。

3. 在JavaScript中实现队列

让我们看一下队列数据结构的可能实现,同时保持所有操作必须在恒定时间内执行的要求O(1)。

class Queue {
  constructor() {
    this.items = {};
    this.headIndex = 0;
    this.tailIndex = 0;
  }

  enqueue(item) {
    this.items[this.tailIndex] = item;
    this.tailIndex++;
  }

  dequeue() {
    const item = this.items[this.headIndex];
    delete this.items[this.headIndex];
    this.headIndex++;
    return item;
  }

  peek() {
    return this.items[this.headIndex];
  }

  get length() {
    return this.tailIndex - this.headIndex;
  }
}

const queue = new Queue();

queue.enqueue(7);
queue.enqueue(2);
queue.enqueue(6);
queue.enqueue(4);

queue.dequeue(); // => 7

queue.peek();    // => 2

queue.length;    // => 3

const queue = new Queue()是如何创建队列的实例。

调用queue.enqueue(7)方法使该项目7进入队列。

queue.dequeue()从队列中取出一个头项,而queue.peek()只是从头检视。

最后,queue.length显示队列中还有多少项目。

关于实现:在Queue类内部,普通对象this.items通过数字索引保留队列中的项目。头项的索引由跟踪this.headIndex,尾项由跟踪this.tailIndex。

  • 队列方法的复杂性

类 Queue 的方法 queue(),dequeue(),peek()和length() 仅使用了:

属性访问(例如this.items[this.headIndex]),

或执行算术操作(例如this.headIndex++)

因此,这些方法的时间复杂度是恒定时间O(1)。

4. 总结

队列数据结构是“先入先出”(FIFO)的一种:最早入队的项是最早出队的项。

队列有2个主要操作:入队和出队。另外,队列可以具有辅助操作,例如检视和长度。

所有队列操作必须在恒定时间内执行O(1)。


以上就是关于JavaScript实现队列的操作是什么,有什么要注意的的介绍,本文内容仅供参考,有需要的朋友可以借鉴了解看看,希望对大家学习或工作,想要了解更多欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2022-08-27 17:49:15 
摘要:php将16进制转为浮点数的方法:1、使用“hexdec(十六进制值)”或者“base_convert(十六进制值,16,10)”语句将16进制值转为十进制数;2、用“floatval(十进制数)”语句获取浮点值,将十进制数转为浮点数类型。
2022-05-31 17:37:54 
摘要:java long占64位,因为一个字节等于8位,所以long占8字节,即64位;其他类型,float占4个字节即32位,char占用的是2个字节即16位。
2022-09-13 17:44:51 
摘要:react虚拟dom的用处:1、提升react代码性能,虚拟DOM是一个js对象,创建一个js对象消耗的性能和创建一个真实DOM要小很多,把创建真实DOM替换为创建虚拟DOM就会有极大的性能上的提升;2、实现跨端应用,在浏览器端是将虚拟DOM转换为一个个的浏览器DOM节点,也可以将他转换为原生应用的组件来实现跨端应用。
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部