数据结构(三)——线性结构之栈Stack

2024-03-31 19:58

本文主要是介绍数据结构(三)——线性结构之栈Stack,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.栈是限定仅在表头进行插入和删除操作的线性表。

   栈在中断处理特别是重要数据的现场保护有着重要意义。

   栈相当于一个箱子,然后往箱子里一层一层的放东西,最先放的最后取,先进后出。

   入口的一端为栈顶,另一端称作栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

2.从数据存储结构来划分,栈可以分为两类:

  • 顺序栈结构:即使用一组地址连续的内存单元依次保存栈中的数据。在程序中,可以定义一个指定大小的结构数组来作为栈,序号为0的元素就是栈底,在定义一个变量top保存栈顶的序号即可。
  • 链式栈结构,即使用链表形式保存栈中各元素的值,链表首部(head引用所指向元素)为栈顶,链表尾部(指向地址为null)为栈底。

3.对栈的操作

本次操作我们考虑的是顺序栈结构的操作,我们可以把栈想像成一个数组,每次插入插入在数组的最后一位,取也从最后一位来取。

栈主要的操作有以下几个:

(1)入栈(Push)(也称压栈):将数据保存到栈顶的操作;

(2)出栈(Pop):将栈顶的数据弹出的操作;

(3)查看栈顶元素;

(4)判断栈是否为空。

package cn.kimtian.array.stack;import java.util.Arrays;/*** 对栈的操作* 由于栈有先进后出的特性* 所以我们考虑若 每次为数组增加元素,加在数组的最后一位,每次取数据也从数组的最后一位取。* 就保证了先进后出。实现了栈的特性。** @author kimtian*/
public class MyStack {/*** 栈的底层我们使用数组来存储数据*/int[] elements;public MyStack() {elements = new int[0];}/*** 压入元素方法** @param element 入栈数据*/public void pushStack(int element) {// 创建一个新的数组int[] newArr = new int[elements.length + 1];// 把原数组中的元素复制到新的数组中for (int i = 0; i < elements.length; i++) {newArr[i] = elements[i];}// 把添加的元素放入新数组中newArr[elements.length] = element;// 使用新数组替换老数组elements = newArr;}/*** 取出栈顶元素*/public int popStack() {// 栈是空的if (elements.length == 0) {throw new RuntimeException("stack is empty!");}// 取出数组的最后一个元素int element = elements[elements.length - 1];// 创建一个新的数组int[] newArr = new int[elements.length - 1];// 把原数组中除了最后元素的其他元素都放入新数组中for (int i = 0; i < newArr.length; i++) {newArr[i] = elements[i];}// 使用新数组替换老数组elements = newArr;// 返回栈顶元素return element;}/*** 查看栈顶元素*/public int peekStack() {// 栈是空的if (elements.length == 0) {throw new RuntimeException("stack is empty!");}// 取出数组的最后一个元素int element = elements[elements.length - 1];return element;}/*** 判断栈是否为空*/public boolean isStackEmpty() {return elements.length == 0;}
}

 

这篇关于数据结构(三)——线性结构之栈Stack的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/865205

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

SpringBoot利用树形结构优化查询速度

《SpringBoot利用树形结构优化查询速度》这篇文章主要为大家详细介绍了SpringBoot利用树形结构优化查询速度,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一个真实的性能灾难传统方案为什么这么慢N+1查询灾难性能测试数据对比核心解决方案:一次查询 + O(n)算法解决

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径