栈与队列的JS实现教程
时间:2025-12-22 14:52:47 423浏览 收藏
怎么入门文章编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《栈与队列的JavaScript实现详解》,涉及到,有需要的可以收藏一下
栈和队列可通过JavaScript数组或自定义类实现。1. 栈遵循后进先出(LIFO),用push/pop操作实现高效入栈出栈;2. 队列遵循先进先出(FIFO),可用push/shift操作,但shift为O(n)影响性能;3. 可通过类封装实现peek、front、isEmpty等方法;4. 栈适用于递归模拟、表达式求值,队列适合任务调度、BFS等场景;5. 高性能需求时建议用对象+指针或链表优化队列实现。

JavaScript 中虽然没有内置的栈和队列类型,但我们可以利用数组或自定义类来实现这两种常用的数据结构。它们在算法设计、函数调用管理、任务调度等场景中非常有用。下面分别介绍栈和队列的基本原理与实现方式。
栈的实现(后进先出)
栈是一种遵循“后进先出”(LIFO, Last In First Out)原则的数据结构。常见的操作包括入栈(push)、出栈(pop)、查看栈顶元素(peek)和判断是否为空。
使用 JavaScript 数组可以轻松模拟栈行为:
- push():将元素添加到栈顶
- pop():移除并返回栈顶元素
- peek():返回栈顶元素但不移除
- isEmpty():判断栈是否为空
以下是基于类的栈实现:
class Stack {
constructor() {
this.items = [];
}
<p>push(element) {
this.items.push(element);
}</p><p>pop() {
if (this.isEmpty()) return undefined;
return this.items.pop();
}</p><p>peek() {
if (this.isEmpty()) return undefined;
return this.items[this.items.length - 1];
}</p><p>isEmpty() {
return this.items.length === 0;
}</p><p>size() {
return this.items.length;
}
}</p>示例使用:
const stack = new Stack(); stack.push(1); stack.push(2); console.log(stack.peek()); // 2 console.log(stack.pop()); // 2 console.log(stack.size()); // 1
队列的实现(先进先出)
队列遵循“先进先出”(FIFO, First In First Out)原则。常用于任务排队、广度优先搜索等场景。基本操作包括入队(enqueue)、出队(dequeue)、查看队首元素(front)和判断是否为空。
虽然可以用数组的 push 和 shift 实现,但 shift 操作的时间复杂度为 O(n),效率较低。下面是一个简单但实用的队列类:
class Queue {
constructor() {
this.items = [];
}
<p>enqueue(element) {
this.items.push(element);
}</p><p>dequeue() {
if (this.isEmpty()) return undefined;
return this.items.shift(); // 注意:shift 是 O(n)
}</p><p>front() {
if (this.isEmpty()) return undefined;
return this.items[0];
}</p><p>isEmpty() {
return this.items.length === 0;
}</p><p>size() {
return this.items.length;
}
}</p>示例使用:
const queue = new Queue();
queue.enqueue('a');
queue.enqueue('b');
console.log(queue.front()); // 'a'
console.log(queue.dequeue()); // 'a'
console.log(queue.size()); // 1
若需更高性能,可考虑使用双指针或链表实现,避免频繁的元素移动。
优化建议与使用场景
在实际开发中,选择合适的数据结构能显著提升代码效率和可读性。
- 栈适用于递归模拟、括号匹配、表达式求值等问题
- 队列适合处理任务调度、消息传递、BFS 等需要顺序处理的场景
- 若对性能要求高,可改用对象 + 指针模拟队列,实现 O(1) 出队
- 注意数组方法的性能差异:pop 和 push 是 O(1),shift 和 unshift 是 O(n)
基本上就这些。掌握栈和队列的手动实现,有助于深入理解 JavaScript 的数据操作机制,也能在不依赖外部库的情况下快速构建逻辑清晰的程序结构。
本篇关于《栈与队列的JS实现教程》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
324 收藏
-
189 收藏
-
429 收藏
-
500 收藏
-
120 收藏
-
306 收藏
-
393 收藏
-
121 收藏
-
393 收藏
-
322 收藏
-
317 收藏
-
310 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习