堆栈(Stack)是一种线性数据结构,其行为类似于现实世界中的项目堆栈。它遵循后进先出(LIFO)的操作顺序,类似于现实世界中的对应物。这意味着新项目将添加到堆栈顶部,项目也将从堆栈顶部移除。
栈数据结构的主要操作有:
push
:将元素添加到堆栈顶部pop
:从堆栈顶部移除元素peek
:检索堆栈顶部的元素,而不删除它isEmpty
:检查堆栈是否为空
class Stack {
constructor() {
this.items = []
}
push(item) {
this.items.unshift(item)
}
pop(item) {
return this.items.shift()
}
peek(item) {
return this.items[0]
}
isEmpty() {
return this.items.length === 0
}
}
- 使用
constructor
创建一个类(class
),为每个实例初始化空数组items
。 - 定义一个
push()
方法,使用Array.prototype.unshift()
将元素添加到items
数组的末尾。 - 定义一个
pop()
方法,使用Array.prototype.shift()
从items
数组的开头删除元素。 - 定义一个
peek()
方法,检索items
数组中第一个元素的值,而不删除它。 - 定义一个
isEmpty()
方法,使用Array.prototype.length
判断items
数组是否为空。
const stack = new Stack()
stack.push('apples')
stack.push('oranges')
stack.push('pears')
stack.isEmpty() // false
stack.peek() // 'pears'
stack.pop() // 'pears'
stack.pop() // 'oranges'
stack.pop() // 'apples'
stack.isEmpty() // true
以上内容来自 30 seconds of code 的 JavaScript Data Structures - Stack