栈
左轮手枪和弹夹手枪,臭弹
栈是限定仅在表尾进行插入和删除操作的线性表。
队列是只允许在一端进行插入操作、而在另一端进行删除操作的线性表。
一、栈
1. 定义
先进后出,后进先出!
ADT 栈 stack
Data
同线性表。相同类型、相邻元素具有前驱和后继关系!
Operation
InitStack(*S) 初始化操作,建立一个空栈S
DestroyStack(*S) 若栈存在,则销毁它
ClearStack(*S) 将栈清空
StackEmpty(S) 若栈为空,返回true,否则返回false
GetTop(S,*e) 若栈存在且非空,用e返回S的栈顶元素
Push(*S,e) 若栈S存在,插入新元素e到栈S中并成为栈顶元素
Pop(*S,*e) 删除栈S中栈顶元素,并用e返回其值
StackLength(S) 返回栈S的元素个数
endADT
面试题
- 会
2. 顺序存储结构代码实现
// 封装栈类
function Stack() {
// 栈中的属性
this.items = []
// 栈的相关操作
/* this.push = function () {
}*/
// 这两种方式,上面种,对内存的消耗较为严重
// 下面这张,相对而言更加适合,节省内存消耗,推荐使用
Stack.prototype.push = function (element) {
this.items.push(element)
}
// 2. 从栈中取出元素
Stack.prototype.pop = function () {
return this.items.pop()
}
// 3. 查看一下栈顶元素
Stack.prototype.peek = function () {
return this.items[this.items.length - 1]
}
// 4. 判断栈是否为空
Stack.prototype.isEmpty = function () {
return this.items.length == 0
}
// 5. 获取栈中元素的个数
Stack.prototype.size = function () {
return this.items.length
}
// 6. toString方法
Stack.prototype.toString = function () {
var resultString = ''
for (var i = 0; i < this.items.length; i++) {
resultString += this.items[i] + ' '
}
return resultString
}
}
- 测试
var s = new Stack()
s.push(20)
s.push(10)
s.push(31)
s.push(11)
alert(s)
// 栈的弹出
s.pop()
s.pop()
alert(s)
alert(s.peek())
alert(s.isEmpty())
alert(s.size())
// 函数:将十进制转成二进制 -- 原理:直接余二,知道为o
function dec2bin(decNumber) {
// 1. 定义栈对象
var stack = new Stack();
// 2. 循环操作
while (decNumber > 0) {
// 1. 将余数结果压入栈
stack.push(decNumber % 2)
// 2. 将结果更新到下一次循环decNumber
decNumber = Math.floor(decNumber / 2)
}
// 3. 从栈中取出 0,1,出栈
var binaryString = ''
while (!stack.isEmpty()) {
binaryString += stack.pop()
}
return binaryString
}
// 测试十进制
var decNumber = 123
console.log("原数字:",decNumber);
console.log("二进制:",dec2bin(decNumber));
应用:十进制转二进制
// 函数:将十进制转成二进制 -- 原理:直接余二,知道为o
function dec2bin(decNumber) {
// 1. 定义栈对象
var stack = new Stack();
// 2. 循环操作
while (decNumber > 0) {
// 1. 将余数结果压入栈
stack.push(decNumber % 2)
// 2. 将结果更新到下一次循环decNumber
decNumber = Math.floor(decNumber / 2)
}
// 3. 从栈中取出 0,1,出栈
var binaryString = ''
while (!stack.isEmpty()) {
binaryString += stack.pop()
}
return binaryString
}
// 测试十进制
var decNumber = 123
console.log("原数字:",decNumber);
console.log("二进制:",dec2bin(decNumber));
3. 链式存储结构
4. 栈的重要应用-递归
5. 栈的应用-四则运算
三种计算应用方式,体会栈的后进先出特性