栈知识点笔记

左轮手枪和弹夹手枪,臭弹

栈是限定仅在表尾进行插入和删除操作的线性表。
队列是只允许在一端进行插入操作、而在另一端进行删除操作的线性表。
一、栈
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

image-20210818173337805

image-20210818173630219

面试题

image-20210920225304877

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. 栈的应用-四则运算

三种计算应用方式,体会栈的后进先出特性

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值