• 技术文章 >web前端 >前端问答

    javascript中有几个栈

    长期闲置长期闲置2022-07-01 14:49:52原创139

    javascript中没有栈,可以使用数组实现栈的所有功能;栈是一种后进先出的数据结构,似乎一种特殊的列表,任何不在栈顶的元素都无法访问,需要先拿掉上面的元素,才能得到栈底的元素,例如可以利用push()将元素添加到栈顶。

    本教程操作环境:windows10系统、javascript1.8.5版、Dell G3电脑。

    javascript中有几个栈

    JavaScript中没有栈,但是可以用数组实现栈的所有功能。

    栈是一种线性结构,最大的特点就是先进后出,后进先出。

    05.png

    入栈push():

    06.gif

    出栈pop():

    07.gif

    栈:

    栈是一种和列表类似的数据结构,可以用它来解决很多的编程问题,栈是一种高效的数据结构,因为数据只能在栈的顶端添加或者删除,所以这样的操作很快而且容易实现。

      栈是一种特殊的列表,站内的元素只能拖过列表的一端进行访问,这一端陈伟栈顶。一叠盘子是最常见的栈结构,只能从顶部取盘子,洗好的盘子也只能放在顶端。栈被称为后入先出的数据结构。

      由于栈具有后入先出的特点,所以任何不在栈顶的元素都无法访问。为了得到栈底的元素,必须拿掉上面的元素。

      对栈的操作有将一个元素压入栈和将一个元素弹出栈。把元素压入栈顶使用push()方法,从栈顶弹出元素使用pop()方法。还有一个方法是预览栈顶元素,使用pop()方法虽然可以访问栈顶的元素,但是调用该方法后栈顶的元素将被永久的删除。peek()方法只返回栈顶的元素,而不删除它。

      为了记录栈顶元素的位置,同时也为了标记从哪里可以加入新元素,我们使用变量top,当向栈内压入元素是该变量增大,从站内弹出元素时,该变量减小。

      pop(),push(),peek()方法是最主要的三个方法,同时定义clear()方法可以清楚栈内所有的元素,length属性定义栈内元素的个数,同时定义一个empty属性标识栈内是否还有元素,不过使用length属性可以达到同样的目的。

    定义栈的操作

      栈作为一种特殊的列表,只能从一端来进行访问,就像一摞盘子,放只能放在上面,拿也只能从上面拿,所以栈是一种先入后出的一种数据结构。因为栈的这种特点,栈中任意不在栈顶的元素都无法访问,为了得到栈底的元素,必须把该元素之上的元素拿掉,把栈底的元素暴露在栈顶。栈还可以清空其内所有元素,也可以记录栈内元素的个数。

      综上,我们定义几个操作栈的方法。

    栈的实现

      实现栈,底层的数据结构采用数组,以定义栈的构造函数开始;

    function Stack() {
        this.dataStore = [];         //用来保存栈内元素的数组
        this.top = 0;                   //top用来记录栈顶位置,初始化为0
        this.push = push;
        this.pop = pop;
        this.peek = peek;
        this.clear = clear;
        this.length = length;
    }

      接下来实现push(),pop(),peek(),clear()和length()。

    push()方法是,当向栈顶添加一个新元素时,在数组的记录栈顶的位置的top的位置添加这个值,添加完成top需要加1;

    pop()正好与push()相反,需要top减1,但同时减1之后返回top位置的值,即已删除元素;

    peek()直接返回数组top-1位置的元素,即栈顶元素就可以了;

    clear() 直接把top值赋为0,直接清空栈;

    length()直接返回top的值,栈顶位置即栈内元素个数

    function push(element) {
        this.dataStore[this.top++] = element;   // 先在top位置加入元素,之后top加1
    }
    function pop() {
        return this.dataStore[--this.top];   // top先减1,然后返回top位置的元素
    }
    function peek() {
        return this.dataStore[this.top - 1];
    }
    function clear() {
        this.top = 0;
    }
    function length() {
        return this.top;
    }

    【相关推荐:javascript视频教程web前端

    以上就是javascript中有几个栈的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript
    上一篇:引入Css样式中link和rel是什么意思 下一篇:javascript是否属于html5
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• JavaScript数据处理的5个常见问题详解• python能代替JavaScript吗• javascript是服务器端脚本语言吗• javascript流程控制语句的作用是什么• javascript数组是自动扩容吗
    1/1

    PHP中文网