js中的数据结构之栈

js中的数据结构之栈

一、定义

栈是一种限定仅在表尾进行插入和删除操作的线性表,遵循后入先出的原则。

二、描述

栈是和列表类似的一种数据结构,也可以说栈就是一种特殊的列表。

栈里面的元素只能通过列表的一端访问,这一端称为栈顶。相对地,把另一端称为栈底。

向一个栈添加新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面使其成为新的栈顶。从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

栈中的数据遵循后入先出原则,所以任何不在栈顶的元素都无法访问到。为了得到栈底的元素,必须先拿掉上面的元素。

三、图示

四、属性和方法描述

对栈的操作主要有两种1、压栈push(向栈中添加一个元素) 2、出栈pop(移除栈中的一个元素)。

我们也可以根据需要定义其他的方法如读取最后一个元素peek(只读取不进行出栈操作),清空clear等。
1、push

向栈中添加一个元素

2、pop

移除栈中的一个元素

3、peek

访问栈顶的元素,不做出栈操作

4、clear

清空栈

5、length

获取栈的长度

五、代码实现

下面我们基于数据这个结构来实现一个栈结构。

复制代码
class Stack {
  constructor() {
    this.dataStore = [];
  }

  // 添加元素
  push(element) {
    this.dataStore.push(element);
  }

  // 移除元素
  pop() {
    return this.dataStore.pop();
  }

  // 仅获取栈顶元素
  peek() {
    return this.dataStore[this.dataStore.length - 1];
  }

  // 清空栈
  clear() {
    this.dataStore = [];
  }

  length() {
    return this.dataStore.length;
  }
}

六、测试

复制代码
const s = new Stack();
s.push(1);
s.push(3);
s.push(5);
console.log("长度: " + s.length()); // 长度: 3
console.log(s.peek()); // 5
const popped = s.pop();
console.log("出栈元素: " + popped); // 出栈元素: 5
console.log(s.peek()); // 3
s.push(7);
console.log(s.peek()); // 7
s.clear();
console.log("长度: " + s.length()); // 长度: 0
console.log(s.peek()); // undefined
s.push(9);
console.log(s.peek()); // 9
相关推荐
星恒随风1 分钟前
Python 基础语法详解(3):顺序语句、条件语句和循环语句一篇讲清楚
开发语言·笔记·python·学习
CHHH_HHH1 分钟前
【C++】红黑树:比AVL树更实用的平衡二叉搜索树
开发语言·数据结构·c++·算法·stl
牛油果子哥q4 分钟前
【C++内存对齐与结构体填充】C++内存对齐与结构体填充深度精讲:对齐规则、结构体内存大小计算、填充冗余、笔试真题与工程优化方案
开发语言·c++
ch.ju6 分钟前
Java程序设计(第3版)第四章——set-get方法
java·开发语言
智能制造产品经理代码提升7 分钟前
快速搭建PayPal标准API测试框架
开发语言·lua
智能制造产品经理代码提升8 分钟前
Postman批量CaptureID全自动查询
开发语言·lua
爱喝水的鱼丶9 分钟前
SAP-ABAP:SAP 内存管理详解:从架构到优化
开发语言·学习·架构·sap·abap·内存管理
_日拱一卒13 分钟前
LeetCode:17电话号码的字母组合
java·数据结构·算法·leetcode·职场和发展
我是一颗柠檬15 分钟前
【Java项目技术亮点】Outbox事件驱动模式:解决分布式事务的终极方案
java·开发语言·分布式·后端·中间件·kafka
那晚的她15 分钟前
Scala中Set集合
开发语言·后端·scala