1.栈是什么

  • 定义:后进者先出,先进者后出,这就是典型的“栈”结构
  • 操作特性:栈是一种“操作受限”的线性表,只允许在一端插入和删除数据。
  • 使用场景;当某个数据集合只涉及在一端插入和删除数据,并且满足后进先出、先进后出的特性,就应该首选“栈”这种数据结构。

2.Java实现顺序栈

用数组实现的栈,我们叫作顺序栈(效率高),而用链表实现的栈,我们叫作链式栈。

2.1 固定大小的栈

  • 时间复杂度:O(1),每次都只操作count(-1)位,与数据规模无关
  • 空间复杂度:O(1),最开始申请了固定大小数组后运行时不再改变大小,与数据规模无关
public class MyStack {// 为了简单,这里直接定义成intprivate int[] items;private int size; // 栈容量private int count; // 栈中实际元素多少// 指定大小构造public MyStack(int size) {this.size = size; this.items = new int[size];this.count = 0;}// push:每次都给items[count]public boolean push(int item) {// 非满判断if (count == size) return false;this.items[count] = item; // 关键count++;return true;}// pop:items[count-1]// 这里count是数组实际元素多少,若不减一返回0public int pop() {// 非空判断if (count == 0) return 0;int item = this.items[count-1]; // 关键count--;return item;}public int peek() {// 这里注意要判断栈中是否有元素return count == 0 ? 0 : this.items[count-1];}
}

上面是基于数组实现的栈,是一个固定大小的栈,也就是说,在初始化栈时需要事先指定栈的大小。当栈满之后,就无法再往栈里添加数据了。

2.2 动态扩容的栈

尽管链式栈的大小不受限,但要存储 next 指针,内存消耗相对较多。因而实现一个基于数组的动态扩容的栈

  • 最好情况复杂度:O(1)
  • 最坏情况复杂度:O(n),满了需要扩容
  • 均摊时间复杂度(if{for}):O(1),平均到每次push相当于每次只扩容一个
public boolean push(int item) {// 满了就扩容,只有push涉及扩容if (count == size) resize();this.items[count] = item;count++;return true;
}private void resize() {int[] newItem = new int[size << 1]; // 将容量变为两倍System.arraycopy(items,0,newItem,0,size); // 关键,所有数组的动态扩容本质上都是数组拷贝this.items = newItem; // 修改指针指向新数组
}

3.栈的应用

3.1 函数调用栈

  • 操作系统给每个线程分配了一块独立的内存空间,这块内存被组织成“栈”这种 结构, 用来存储函数调用时的临时变量
  • 每进入一个函数,就会将临时变量作为一个栈帧入栈,当被调用函数执行完成返回之后,将这个函数对应的栈帧出栈
int main() {   int a = 1;  int ret = 0; int res = 0;  ret = add(3, 5);res = a + ret; printf("%d", res);   reuturn 0;\
}int add(int x, int y) {   int sum = 0;sum = x + y; return sum;
}

3.2 实现计算器

  • 使用两个栈:操作数栈和符号栈
  • 操作数和符号依次入栈,当 - 和 ÷ 要入栈时清空栈(操作数先出栈,符号再出栈 —> 结果)

比如现在要计算 3 + 5 x 8 - 6 的结果,过程其实很简单:

3.3 浏览器后退前进

使用两个栈:X(后退栈) 和 Y(前进栈)

  • 把首次浏览的页面依次压入栈 X。比如你顺序查看了 a,b,c 三个页面,我们就依次把 a,b,c 压入栈,这个时候,两个栈的数据就是这个样子:

  • 当点击后退按钮时,再依次从栈 X 中出栈,并将出栈的数据依次放入栈 Y。比如从页面 c 后退到页面 a 之后,就依次把 c 和 b 从栈 X 中 弹出,并且依次放入到栈 Y

  • 当我们点击前进按钮时,我们依次从栈 Y 中取出数据,放入栈 X 中。比如这个时候你又想看页面 b,于是你又点击前进按钮回到 b 页面,我们就把 b 再从栈 Y 中出 栈,放入栈 X 中

  • 当栈 X 中没有数据时,那就说明没有页面可以继续后退浏览 了。当栈 Y 中没有数据,那就说明没有页面可以点击前进按钮浏览了。比如,你通过页面 b 又跳转到新的页面 d 了,页面 c 就无法再通过前进、后退按钮重复查看了,所以需要清空栈 Y

【数据结构】栈:Java实现顺序栈栈应用浅析相关推荐

  1. 【Java数据结构】3.1 顺序栈

    栈 定义: 栈(Stack)是一个后进先出(Last in first out,LIFO)的线性表,它要求只在表尾进行删除和插入操作. 图如下: 特点: 一.栈特殊的线性表(顺序表.链表),它在操作上 ...

  2. 在java的实现栈的插入数据_栈之Java实现数据结构

    一.什么是栈? 栈(stack)又叫先进后出表,它是一种运算受限的线性表.它只允许在表的一端进行插入和删除操作,我们称之为栈顶,相对另一端称为栈底. 我们可以通俗一点,将栈比喻为一个垃圾桶,垃圾桶底就 ...

  3. 【数据结构】栈-顺序栈、链式栈、共享栈

    栈的定义 栈(Stack):只允许在一端进行插入或删除操作的线性表 栈顶(Top):线性表允许进行插入和删除的那一端. 栈底(Bottom):固定的,不允许进行插入和删除的另一端. Tips: 1.栈 ...

  4. java实现顺序栈_Java实现顺序栈原理解析

    这篇文章主要介绍了java实现顺序栈原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 什么是栈 1.栈的英文是stack 2.栈是一个先入后出 ...

  5. 数据结构笔记--栈的总结及java数组实现简单栈结构

    杂谈"栈"结构: 栈(Stack)是一种插入删除操作都只能在一个位置上进表,这个位置位于表的末端,叫做栈顶(Top). 对栈的基本操作有push和pop,表示进栈和出栈.也就相当于 ...

  6. java顺序栈和链栈_Java的顺序栈和链式栈

    栈的定义 栈是限制在表的一段进行插入和删除的运算的线性表,通常能够将插入.删除的一端为栈顶,例外一端称为栈底,当表中没有任何元素的时候称为空栈. 通常删除(又称"退栈")叫做弹出p ...

  7. java 顺序栈_Java实现顺序栈

    一.分析 栈是限定仅在表的一端进行插入或删除操作的线性表,对于栈来说,操作端称为栈顶,另一端则称为栈底,栈的修改是按照后进先出的原则进行的,因此又称为后进先出的线性表. 顺序栈是指利用顺序存储结构实现 ...

  8. 数据结构C++实现(顺序栈) 青岛大学王卓老师

    b站  <数据结构与算法基础(青岛大学-王卓)> 所用教材<数据结构C语言版第二版> 中国工信出版集团 人民邮电出版社出版 严蔚敏 编著 #include<iostrea ...

  9. Java之根据入栈顺序是否能得到出栈顺序

    入栈.出栈顺序匹配 前言 一.Java入栈.出栈 1.例题 二.题解 A.纯正的模拟 B.LinkedHashSet C.利用CPU 总结 参考文献 前言 给出入栈顺序,匹配一个出栈顺序是否合法,即出 ...

最新文章

  1. webpack 3 零基础入门教程 #13 - 生产环境 vs 开发环境
  2. Delphi中使用ListView和TreeView的Item中的Data可能被忽略的内存泄漏
  3. mysql 导入txt数据到数据表【原创】
  4. 初识Maven POM
  5. C++内存管理——指针数组
  6. 【转】添加web引用和添加服务引用有什么区别?
  7. centos 开发环境配置
  8. 蚂蚁金服 3 个项目进入 CNCF 云原生全景图 | 开源
  9. 事件 ID 3001错误的解决方法
  10. 微信公众开放平台开发02---微信公众平台PHP接口和java接口对比
  11. 优秀程序员是怎样提高敲代码的效率?有这些工具就够了!
  12. 09. 慎重选择删除元素的方法
  13. java中多线程介绍
  14. scratch算立方根
  15. 直角坐标系与极坐标系了解与转换
  16. PP相关的 bapi
  17. SDIO2019R2游记&入坑2周年感想
  18. vim 一些常用命令
  19. Android系统手机的ROOT的那些事儿~ 附主流手机的ROOT图文教程和工具下载
  20. Python函数 — 位置参数和关键字参数

热门文章

  1. JDBC原理实现详解
  2. 数字广东:共建区块链开源生态,实现高水平科技自立自强
  3. 两个有序数组的中位数
  4. JavaSE:第十二章:IO流
  5. Java8特性详解(一):行为参数化--将代码传递给方法
  6. 生成订单php setinc,ThinkPHP 统计数据(数字字段)更新 setInc 与 setDec 方法,加减...
  7. 我的世界服务器菜单怎么做制作教程,我的世界服务器公告栏怎么做 教你用命令方块制作公告栏...
  8. 我读《计算机科学概论》第12版 J.Gleen.Brookshear Dennis Brylow
  9. 台湾精锐Apex行星减速机安装步骤及注意事项
  10. Opencv之视频入门