JAVA初阶数据结构栈(工程文件后续会上传)(+专栏数据结构练习是完整版)

1.栈的概念讲解(Stack))

定义:栈是一种先进后出的数据结构

要想拿到12就要把它头上的所有东西给移出去 

 2.栈的实现(代码)

2.1栈的方法逻辑的讲解

(1)新建一个测试类Frank

(2)进入源码进行分析

其中栈就只有3个方法

pop (弹出元素)stack (放入元素)peek(输出元素)

其中如果选中pop相当于删除这个要弹出的元素

其中如果选中peek相当于获取栈内元素但是不删除

empty方法是用来判断栈是否为空的

(3)图解

栈本质上是一个数组()

定义一个useSize它的作用写道图片里面了

2.2栈中的push方法的实现(压栈操作)

先定义一个数组,(栈就是数组)然后定义一个数组长度usesize代表数组的长度,elem是数组,然后定义一个长度为10的数组。

 鉴于我们之前实现的顺序表的操作,我们首先要先定义一个判断栈是否为满的方法(isFull方法)

这个方法

 之后利用这个方法来实现入栈操作

如果这个数组为满,那么数组的长度就扩容两倍,之后useSize的第useSize+1的位置等于要先高要加入的元素

 2.3pop方法(弹出栈定元素操作)

我们删除只需要将上面的代码给usedSize给变成--然后剪刀3位置,然后回收

代码实现

首先定义一个isEmpty方法来判断数组是否为空

定义一个异常类,当发生数组为空的时候记得报错。

总体代码

 2.4peek(查看栈中元素(栈定元素)操作)

既然我们不需要进行弹出,那么我们就不需要usesize--来对数组(栈)进行操作

所以和上面代码差不多,如果想简化可以把return old改成elem【usiedsize--】

代码实现

2.5. 总结

入栈出栈的时间复杂度都为1,

2.6通过链表实现栈

通过链表实现栈可以使用单链表,也可以使用双链表,不管使用哪个链表一定要保证,入栈出栈的操作时间复杂度都为o(1)(我写的这些是为了能够让你们更好的了解)

2.6.1单向链表实现栈(可以实现队列和栈)

如果用尾插法那么遍历整个链表就不是o(1)

所以要用头插法

入栈用头插法

删除就删除头结点

图解

2.6.2双向链表实现栈(可以实现队列和栈)

双向链表的化head和last都可以来实现栈

由于在jdk中实现的就是双向链表,所以我们实例化一个双向链表

进入源码

 可以看到在源码中又push方法来压栈

其中还有pop方法来弹出栈

还有peek方法

k

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/537118.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

借助ChatGPT提高编程效率指南

PS: ChatGPT无限次数,无需魔法,登录即可使用,网页打开下面 一、借助ChatGPT提高编程效率指南 随着计算机技术的飞速发展,编程已经成为了现代社会中一个非常重要的技能。对于许多人来说,编程不仅是一项工作技能,而且是…

【linux】搜索所有目录和子目录下的包含.git的文件并删除

一、linux命令搜索所有目录和子目录下的包含.git的文件 在Linux系统中,要搜索所有目录和子目录下的包含.git的文件,可以使用find命令。find命令允许指定路径、表达式和操作来查找文件。 以下是使用find命令搜索包含.git的文件的方法: 1. 基…

《高效便捷,探索快递柜系统架构的智慧之路》

随着电商业务的蓬勃发展,快递柜系统作为一种高效、便捷的最后一公里配送解决方案,正在受到越来越多企业和消费者的青睐。本篇博客将深入探讨快递柜系统的架构设计理念、优势和实践,帮助读者了解如何构建智能化的快递柜系统,提升物…

STM32平替GD32有多方便

众所周知, GD32一直模仿STM32,从未被超越。 我最近公司使用的GD32E230C6T6 这款芯片有48个引脚。 属于小容量的芯片。 我有一个用STM32写的代码,之前是用的 STM32F103CB 这款芯片是中容量的。 不过在keil中,只需要这两步,就能使用原来的逻辑,几乎不用修改代码。 1. …

《智能便利,畅享便利柜平台的架构奇妙之旅》

便利柜平台作为一种智能化、便捷的自助服务解决方案,正在逐渐走进人们的生活。本篇博客将深入探讨便利柜平台的架构设计理念、优势和实践,帮助读者了解如何构建智能便利柜平台,提供更便捷的自助服务体验。 ### 便利柜平台架构设计 #### 1. …

网络编程-套接字相关基础知识

1.1. Socket简介 套接字&#xff08;socket&#xff09;是一种通信机制&#xff0c;凭借这种机制&#xff0c; 客户端<->服务器 模型的通信方式既可以在本地设备上进行&#xff0c;也可以跨网络进行。 Socket英文原意是“孔”或者“插座”的意思&#xff0c;在网络编程…

Jenkins安装部署

目录 一、CI/CD介绍 二、持续集成与持续交付 持续集成&#xff08;CI&#xff09; 持续交付&#xff08;CD&#xff09; 持续集成的组成要素 持续集成的好处 持续集成的流程 三、Gitlab简介与特点 四、Gitlab CI/CD工作原理 五、Gitlab的部署与安装 安装依赖环境 G…

docker-compose部署及使用

Docker Compose是一个用于定义和运行多个Docker容器的工具。它使用YAML文件来配置应用程序的服务、网络和卷等方面&#xff0c;使得在单个主机上进行部署更加简单。通过定义一个Compose文件&#xff0c;你可以一次性启动、停止和管理整个应用程序的多个容器。 Compose文件包含了…

【每日一题】[信息与未来 2023] 幸运数字题解(枚举 模拟)

标签&#xff1a;数位拆分、枚举、模拟题意&#xff1a;给定区间 [ a , b ] [a,b] [a,b]&#xff0c;求出区间内满足奇数位和等于偶数位和的数字个数题解&#xff1a;遍历区间内每个数字&#xff0c;统计其奇数位和与偶数位和&#xff0c;如果相等&#xff0c;计数器加一&#…

Stability AI与VAST推出TripoSR:快速3D建模新时代,0.5秒生成3D模型

前言 在人工智能领域&#xff0c;3D内容生成技术正迅速成为创新的前沿。最近&#xff0c;Stability AI与华人团队VAST联合推出的TripoSR模型&#xff0c;标志着3D建模进入了一个新的快速时代。此次合作不仅展示了技术的飞跃发展&#xff0c;也为开发者和创意工作者提供了前所未…

CSS3动画有哪些?

文章目录 一、是什么二、实现方式transition 实现渐变动画transform 转变动画animation 实现自定义动画 三、总结参考文献 一、是什么 CSS动画&#xff08;CSS Animations&#xff09;是为层叠样式表建议的允许可扩展标记语言&#xff08;XML&#xff09;元素使用CSS的动画的模…

使用ScottPlot库在.NET WinForms中快速实现大型数据集的交互式显示

前言 在.NET应用开发中数据集的交互式显示是一个非常常见的功能&#xff0c;如需要创建折线图、柱状图、饼图、散点图等不同类型的图表将数据呈现出来&#xff0c;帮助人们更好地理解数据、发现规律&#xff0c;并支持决策和沟通。本文我们将一起来学习一下如何使用ScottPlot库…