文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript如何实现栈结构

2023-06-21 23:30

关注

小编给大家分享一下JavaScript如何实现栈结构,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

一、认识栈结构

我们知道数组是一种常见的数据结构,并且可以在数组的任意位置插入和删除数据,但是有时候,我们为了实现某些功能,必须对这种任意性加以限制,而栈和队列就是比较常见的受限的数据结构,我们先来看看栈。
栈(stack),它是一种受限的线性表,后进先出(LIFO

其结构图如下所示:

JavaScript如何实现栈结构

生活中类似于栈的

例如:当我们敲代码时,如果发生错误需要删除,那么最先敲上去的是最后被删除的。

接下来我们就一起来实现一下栈结构的封装,将采用的方式是基于数组实现的。

二、栈结构封装

首先创建一个类封装栈结构,如下:

function Stack(){                    }

在其内部添加属性和方法,将数组通过属性的方法添加给该类。然后采用原型的方法添加常用的操作。

栈常用的操作有:

接下来,我们就来将他们一一实现:

 function Stack(){     this.items = [];     // 添加一个新元素到栈顶位置。push()     Stack.prototype.push = function(element){        this.items.push(element);     }      // 移除栈顶的元素pop()     Stack.prototype.pop = function(){         return this.items.pop();     }     //  返回栈顶的元素,不对栈做任何修改peek()     Stack.prototype.peek = function(){         return this.items[this.items.length-1];     }     // 判断栈是否空isEmpty()     Stack.prototype.isEmpty = function(){         if(this.items.length == 0){             return true;         }else {             return false;         }     }     // 返回栈里的元素个数size()     Stack.prototype.size = function(){         return this.items.length;     }     // 将栈结构的内容以字符形式返回toString()     Stack.prototype.toString = function(){         var str = '';         for(var i =0;i<this.items.length;i++){             str += this.items[i] + ' ';         }         return str;     } }

注意:这里为什么要通过原型的方式添加呢?是因为通过该方法添加的方法是添加在类上的,而如果直接通过this来添加,是添加到具体的实例对象上的,会造成浪费内存的情况。

最后进行验证。代码如下:

var stack = new Stack();stack.push(1);stack.push(2);stack.push(3);stack.push(4);stack.push(5);console.log(stack);console.log('移除的栈顶元素是:'+stack.pop());console.log('栈顶元素为:'+stack.peek());console.log('栈是否为空:'+stack.isEmpty());console.log('栈里的元素个数是:'+stack.size());console.log('栈结构的内容是:');console.log(stack.toString());

输出结果为:

JavaScript如何实现栈结构

构建成功。
接下来来看一个实例!

三、十进制转化为二进制

如何实现十进制转化为二进制呢?

要把十进制转化成二进制,我们可以将该十进制数字和2整除,将得到的余数压入栈中,直到结果是0为止,最后在将得到的栈中元素依次出栈,得到最终结果,

如下图所示:

JavaScript如何实现栈结构

具体代码为:

 function Stack(){     this.items = [];     //入栈     Stack.prototype.push = function(element){         this.items.push(element);     }     //出栈     Stack.prototype.pop = function(){         return this.items.pop();     }     //判断栈是否为空     Stack.prototype.isEmpty = function(){         if(this.items.length == 0){             return true;         }else{             return false;         }     } } function decToBin(decNumber){      var stack = new Stack;      while(decNumber>0){          //获取余数,放入栈中          stack.push(decNumber%2);          //获取新的除数          decNumber = Math.floor(decNumber/2);      }      //获取栈顶元素      var str = '';      while(!stack.isEmpty()){          str += stack.pop();      }      return str;  } console.log('100转化成二进制是:'+decToBin(100)); console.log('50转化成二进制是:'+decToBin(50)); console.log('20转化成二进制是:'+decToBin(20)); console.log('34转化成二进制是:'+decToBin(34));

输出结果为:

JavaScript如何实现栈结构

看完了这篇文章,相信你对“JavaScript如何实现栈结构”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯