数据结构(三)——线性结构之栈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

相关文章

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. 拖拽路径

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要