线性数据结构-队列

队列(Queue)是一种先进先出(First In First Out, FIFO)的数据结构,它按照元素进入的顺序来处理元素。队列的基本操作包括:

  • enqueue:在队列的末尾添加一个元素。
  • dequeue:移除队列的第一个元素,并返回被移除的元素。
  • front 或 peek:返回队列的第一个元素,但不移除它。
  • isEmpty:检查队列是否为空。
  • size:返回队列中元素的数量。

数组实现队列

  • 内存连续性:数组在内存中是连续分配的,这有助于利用现代处理器的缓存机制,提高访问速度。
  • 动态扩容:数组需要预先定义大小或动态扩容。动态扩容涉及到创建新数组并复制旧数组元素的操作,这个操作的时间复杂度为O(n)。
  • 插入和删除操作:在队列末尾插入元素(enqueue)的时间复杂度为O(1),但在队列开头删除元素(dequeue)时,由于需要移动所有后续元素,时间复杂度也为O(n)。不过,如果只在数组末尾进行操作,这个复杂度可以降低到O(1)。
javascript 复制代码
class Queue {
    contructor(){
        this._queue = [];
    }

    isEmty() {
        return this._queue.length === 0;
    }

    enqueue(value) {
        this._queue.push(value);
    }

    dequeue() {
        if (this.isEmty()) {
            return undefined;
        }
        return this._queue.shift();
    }
    
    size() {
        return this._queue.length;
    }

    peek() {
        if (this.isEmty()) {
            return undefined;
        }
        return this._queue[0];
    }
}

链表实现队列

  • 内存分配:链表节点在内存中可以分散分配,不需要连续的内存空间。
  • 动态大小:链表可以根据需要动态地分配节点,不需要担心扩容问题。
  • 插入和删除操作:在链表队列的末尾插入元素(enqueue)和从头部删除元素(dequeue)的时间复杂度都为O(1),因为只需要改变指针的指向。
  • 额外开销:链表操作涉及到额外的指针操作,可能会有一些性能开销,尤其是在js中,对象和指针的处理通常比原始数据类型慢。
javascript 复制代码
class Node {
    constructor(value){
        this.value = value;
        this.next  = null;
    }
}


class Queue {
    contructor(){
        this._front = null
        this._rear = null
        this._size = 0
    }

    isEmty() {
        return this._size === 0;
    }

    size() {
        return this._size;
    }

    dequeue() {
        if (this.isEmty()) {
            return undefined;
        }
        this._size--
        const removeNode = this._front
        this._front = this._front.next
        if (this.isEmty()) {
            this._rear = null
        }
        return removeNode.value;
    }
    
    enqueue(value) {
        const newNode = new Node(value)
        if (this.isEmty()) {
            this._front = newNode
            this._rear = newNode
        } else {
            this._rear.next = newNode
            this._rear = newNode
        }
        this._size++
    }
    peek() {
        if (this.isEmty()) {
            return undefined;
        }
        return  this._front.value;
    }
}
相关推荐
2401_873479404 小时前
如何利用IP查询定位识别电商刷单?4个关键指标+工具配置方案
开发语言·tcp/ip·php
我爱cope4 小时前
【从0开始学设计模式-10| 装饰模式】
java·开发语言·设计模式
菜鸟学Python5 小时前
Python生态在悄悄改变:FastAPI全面反超,Django和Flask还行吗?
开发语言·python·django·flask·fastapi
浪浪小洋6 小时前
c++ qt课设定制
开发语言·c++
charlie1145141916 小时前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构
故事和你916 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
幺风6 小时前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
程序猿编码7 小时前
给你的网络流量穿件“隐形衣“:手把手教你用对称加密打造透明安全隧道
linux·开发语言·网络·安全·linux内核
ID_180079054737 小时前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A7 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact