内容简介:在数据结构与算法中,栈(stack)又名堆栈,栈是一种受限的线性储存结构,只允许在一端加入元素和删除元素。这一端称为栈顶,加入元素称作入栈、压栈、进栈;删除元素又称作出栈、退栈。被删除元素的相邻元素会重新称为栈顶元素。栈遵循先进后出(FILO)的规则。在编程语言中很多时候使用到栈的数据结构。例如函数栈结构。A函数调用B函数,B函数调用了C函数。语言执行先会把A函数、B函数、C函数依次进栈;待C函数执行完成出栈,B函数出栈,最后A函数完成出栈。生活中具有比较多的类似于栈的结构,比如叠罗汉、子弹夹、文件叠在一起
在数据结构与算法中,栈(stack)又名堆栈,栈是一种受限的线性储存结构,只允许在一端加入元素和删除元素。这一端称为栈顶,加入元素称作入栈、压栈、进栈;删除元素又称作出栈、退栈。被删除元素的相邻元素会重新称为栈顶元素。栈遵循先进后出(FILO)的规则。
栈结构示意图
栈结构使用
在编程语言中很多时候使用到栈的数据结构。例如函数栈结构。A函数调用B函数,B函数调用了C函数。语言执行先会把A函数、B函数、C函数依次进栈;待C函数执行完成出栈,B函数出栈,最后A函数完成出栈。
生活中具有比较多的类似于栈的结构,比如叠罗汉、子弹夹、文件叠在一起等等。理解栈结构原理对我们编程具有很大的帮助。下面会使用 JavaScript实现我们的栈结构。
实现栈结构的功能
- push(element):push是进栈操作,其中element是需要进栈的元素,返回操作成功与否布尔值。
- pop():pop移除栈顶元素操作,返回移除的栈顶元素。
- size():获取栈中的栈元素数量,返回一个数字。
- isEmpty():判断栈是否为空,返回一个布尔值。
- peek():返回栈顶元素,但不移除栈顶元素。
- bottom():返回栈底元素。
- clear():清除所有栈元素,返回操作成功与否布尔值。
进栈与出栈流程
ES6 栈结构代码
class Stack { constructor() { this.lists = []; } size() { return this.lists.length; } isEmpty() { return this.lists.length === 0; } peek() { const topIndex = this.size() - 1; return this.lists[topIndex]; } bottom() { return this.list[0]; } push(element) { this.lists.push(element); return true; } pop() { return this.lists.pop(); } clear() { this.lists = []; return true; } toString() { let result = ""; this.lists.forEach(value => { result = result + "" + value; }); return result; } } 复制代码
ES5 栈结构代码
通过ES5把功能函数可以绑定在对象的实例上,也可以把功能函数加在函数的原型链上
function Stack() { this.lists = []; } Stack.prototype.push = function (element) { this.lists.push(element); return true; } Stack.prototype.pop = function () { return this.lists.pop(); } Stack.prototype.clear = function () { this.lists = []; return true; } Stack.prototype.peek = function () { var topIndex = this.size() - 1; return this.lists[topIndex]; } Stack.prototype.size = function () { return this.lists.length; } Stack.prototype.isEmpty = function () { return this.lists.length === 0; } Stack.prototype.bottom = function () { return this.lists[0]; } Stack.prototype.toString = function () { var result = ""; for (var i = 0; i < this.lists.length; i++) { result = result + '' + this.lists[i]; } return result; } 复制代码
ES5和ES6实现栈结构已经通过了测试可运行。上面是通过数组实现的栈结构,其实链表也可以实现栈结构。下面数据结构链表篇会使用链表实现栈的数据结构
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 数据结构 – 用于构建文件系统的数据结构?
- 荐 用Python解决数据结构与算法问题(三):线性数据结构之栈
- 数据结构和算法面试题系列-C指针、数组和结构体
- 请问二叉树等数据结构的物理存储结构是怎样的?
- 数据结构——单链表
- 常用数据结构
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python编程
[美]埃里克·马瑟斯 / 袁国忠 / 人民邮电出版社 / 2016-7-1 / CNY 89.00
本书是一本针对所有层次的Python 读者而作的Python 入门书。全书分两部分:第一部分介绍用Python 编程所必须了解的基本概念,包括matplotlib、NumPy 和Pygal 等强大的Python 库和工具介绍,以及列表、字典、if 语句、类、文件与异常、代码测试等内容;第二部分将理论付诸实践,讲解如何开发三个项目,包括简单的Python 2D 游戏开发如何利用数据生成交互式的信息图......一起来看看 《Python编程》 这本书的介绍吧!