javascript:数据结构——栈

栈结构的概念

是一种“后进先出”的数据结构。

栈作用

在编程语的编译器和内存中保存变量、方法调用

栈操作

在这里插入图片描述

栈结构操作的方法

push():进栈
pop():出栈
peek():检查栈顶元素
isEmpty():是否为空
clear():清空栈
size():栈元素个数
在这里插入图片描述

js实现栈结构–数组

在这里插入图片描述

使用类封装栈操作

const Stack = function () {
        
   const items = []; //私有的,只能在函数内部十使用,外部访问不到
   // this.items = [];//共有的,外部可以访问

   // push 栈顶添加元素
   this.push = function (element) {
     items.push(element)
   }

   // pop 栈顶移除元素
   this.pop = function(){
     // 这里使用 return 是为了返回删除的元素
     return items.pop()
   }

   // peek 检查栈顶元素
   this.peek = function(){
     return items[items.length-1]
   }

   // isEmpty 栈是否为空(一般is开头命名的返回Boolean类型)
   this.isEmpty = function(){
     return items.length == 0
   }

   // clear 清空栈
   this.clear = function(){
     return items = [];
   }

   // size 栈元素个数
   this.isEmpty = function(){
     return items.length
   }

   // 检查items
   this.getItems = function(){
     return items
   }
 }

使用栈思想实现进制转化

// 使用栈思想实现进制转化
// 参数1 转化的进制数
// 参数2 需要转化为几进制
const binaryConversion = function(num,num2){
  var stack = new Stack();
  var str = '';
  while(num>0){
    stack.push(num % num2)
    num = Math.floor( num / num2)
  }
  while(!stack.isEmpty()){
    str += stack.pop(); 
  }
  return str;
}

栈和函数
在计算机内存栈中是先调用先入栈,而出栈的方式只有一个是“先入后出”
在这里插入图片描述

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值