栈的简单介绍

一.栈

栈是一种先进后出的结构:(先出来的是45,要出12就必须先把前面的数据全部出完。)

2.实例化一个栈对象:

3.入栈:

4.出栈:(当走完pop就直接弹出45了。)

5.出栈的返回值可以接收:

6.peek只看当前数据并不会像pop一样删除数据:

7.Stack继承Vector,但是Vector过时了。

二.自己实现栈

1.通过数组来表示栈:

2.入栈:

3.出栈:

4.peek:

三.Stack的题

1.这道题选C:(这里的栈不是依次放入和依次取出的,所以说一下A为什么对,其余的都是类比方法。我们可以先对1进行入栈,之后在对1进行出栈,然后在对2 3 4依次压栈,在对2 3 4依次出栈就是4 3 2所以A是对的。)

2.这道题选B:(需要注意的是这里的题是依次入栈和压栈,所以就只能选B,看题一定要仔细)

3.把递归转化为循环:

4.逆波兰表达式求值:(算法是中缀表达式的从左往右按照算法的优先级加小括号,然后在从左往右通过算法的优先级取出操作符,然后算出这个后缀表达式,我们将得到的后缀表达式中数字先进行入栈,遇到运算符就出栈两个数据,第一个出栈的数据作为右操作数,第二个出栈的为左操作数,然后进行运算之后的数字再入栈进行计算,最后一个数入栈的数字就是结果。)

代码:

有效的括号匹配:

(思路:用栈来完成,这道题的思路就是给了一个括号字符串({}),我们需要拿到最里面的左括号那么需要通过入栈然后再出栈就能拿到最里面的左括号,那么意思就是当为左括号的时候就入栈,当为右括号的时候就不再入栈而是出栈了,所以刚刚的字符串当我们拿到最后一个 { 的时候,下一个为右括号则不在入栈,就要出栈看是否与这个右括号匹配,匹配的话我们就继续比对下一个右括号,如果还是配对的话这个字符串就遍历完了,这里的遍历是通过循环来遍历的,然后退出循环,此时的栈是空的,也就说明这个配对的情况是在循环走完,并且栈是空的才是完全配对的(循环走完),所以当第二个例子,我们就可以看出拿到最里面的括号的时候,不配对就直接返回false后就可以了,第三个例子就是只有一个左括号,有多个右括号,当配对完一个循环还没走完,但是栈空了(此时是在循环内部栈空的,说明此时字符串还没遍历完,代表该字符串括号没有多余的左括号来进行匹配了),此时也是不匹配的所以返回false。第四种情况就是左边括号多了,配对完一个右括号,循环就走完了,但是此时的栈不是空的,所以也是不匹配的返回一个false。)

代码:

出栈入栈次序匹配:(思路:既然要入栈的顺序是定的,那么我们判断出栈的顺序就是通过循环来判断。我们给入栈顺序的数组下标为 i 出栈数组的下标为 j ,我们通过遍历入栈顺序的数组来进行入栈数据,当入栈的元素与出栈元素想相同时我们就一直出栈,不同的时候在进行循环,如果循环结束并且栈为空那么这个入栈顺序的数组和这个出栈顺序的数组是匹配的。需要注意的是,当我们在进行判断是否需要出栈时的条件时,我们需要先判断的是,j 的值不能超过出栈数组的长度,并且栈不能为null不然我们就无法对栈中的元素和出栈顺序数组的元素来进行匹配了)

最小栈:(题设的要求是自己写一个找到最小的数据的时间复杂度是常数,那么这都题就需要两个栈,一个栈是用来存放实际数据的,另一个栈是来存放最小数据的,这样我们就可以直接出栈最小的数据。这里需要注意的是,入栈的时候如果存放第一个数据的时候,两个栈都要存放数据在里面。出栈的时候是直接出的正常栈的数据,但是我们需要知道,如果正常栈的栈顶数据就是最小的数据,那么最小栈的数据也要将这个数据出栈,这里出栈的时候需要判断最小栈是否为null保证安全性。还需要知道在比较两个引用类型的时候我们要用equals来比较两个是否相同,通过equals的返回值可以确定。或者把另一个数据拆箱成基本数据类型就可以直接用==来比较了。这里用equals比较的话会比较浪费时间)

四.链表也可以实现栈的功能:(其中的push和pop都是头插和头删)

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

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

相关文章

java韩顺平最新教程,Java工程师进阶

简介 HikariCP 是用于创建和管理连接,利用“池”的方式复用连接减少资源开销,和其他数据源一样,也具有连接数控制、连接可靠性测试、连接泄露控制、缓存语句等功能,另外,和 druid 一样,HikariCP 也支持监控…

HCIA项目实践--RIP相关原理知识面试问题总结回答

9.4 RIP 9.4.1 补充概念 什么是邻居? 邻居指的是在网络拓扑结构中与某一节点(如路由器)直接相连的其他节点。它们之间可以直接进行通信和数据交互,能互相交换路由信息等,以实现网络中的数据转发和路径选择等功能。&am…

【ThreeJS Basics 1-3】Hello ThreeJS,实现第一个场景

文章目录 环境创建一个项目安装依赖基础 Web 页面概念解释编写代码运行项目 环境 我的环境是 node version 22 创建一个项目 首先,新建一个空的文件夹,然后 npm init -y , 此时会快速生成好默认的 package.json 安装依赖 在新建的项目下用 npm 安装依…

【JavaEE进阶】依赖注入 DI详解

目录 🌴什么是依赖注入 🎄依赖注入的三种方法 🚩属性注⼊(Field Injection) 🚩Setter注入 🚩构造方法注入 🚩三种注⼊的优缺点 🌳Autowired存在的问题 🌲解决Autowired存在的…

在Mac arm架构终端中运行 corepack enable yarn 命令,安装yarn

文章目录 1. 什么是 Corepack?2. 运行 corepack enable yarn 的作用3. 如何运行 corepack enable yarn4. 可能遇到的问题及解决方法问题 1:corepack 命令未找到问题 2:Yarn 未正确安装问题 3:权限问题 5. 验证 Yarn 是否启用成功6…

16.React学习笔记.React更新机制

一. 发生更新的时机以及顺序## image.png props/state改变render函数重新执行产生新的VDOM树新旧DOM树进行diff计算出差异进行更新更新到真实的DOM 二. React更新流程## React将最好的O(n^3)的tree比较算法优化为O(n)。 同层节点之间相互比较,不跨节点。不同类型的节…

SQL数据清理:去除字段值中的多余符号(Demo例子)

目录 前言1. 基础2. 进阶 前言 Excel中有大量不合法的符号,导入到系统之后,数据库有很多脏数据,对此下述展开sql的清洗教程 在数据库的文本字段中,可能会存在多余的逗号或符号,如,销售,, 或 二手车,销售,,这种情况 希…

计算机组成原理

观看地址如下【2019版】1.3.2 性能指标2——速度_哔哩哔哩_bilibili 第一章 计算机系统概述 了解 #低电平高电平 #计算机的发展 主要是因为逻辑元件的限制 选择题 微处理器的发展 这里的机器字长为 软硬件的发展 几种指令和数据流 计算机的系统结构 需求产生变化 电信号…

基于MATLAB的沥青试样孔隙率自动分析——原理详解与代码实现

摘要 在材料科学与土木工程领域,沥青孔隙率是评价其耐久性和稳定性的重要指标。本文提出一种基于图像处理的孔隙率自动计算方法,通过MATLAB实现灰度化、对比度增强、形态学处理等关键步骤,最终输出试样孔隙率。代码注释清晰,可直…

【嵌入式Linux应用开发基础】open函数与close函数

目录 一、open函数 1.1. 函数原型 1.2 参数说明 1.3 返回值 1.4. 示例代码 二、close函数 2.1. 函数原型 2.2. 示例代码 三、关键注意事项 3.1. 资源管理与泄漏防范 3.2. 错误处理的严谨性 3.3. 标志(flags)与权限(mode&#xff…

【通俗易懂说模型】一篇弄懂几个经典CNN图像模型(AlexNet、VGGNet、ResNet)

🌈 个人主页:十二月的猫-CSDN博客 🔥 系列专栏: 🏀深度学习_十二月的猫的博客-CSDN博客 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 目录 1. 前言 2. …

Android 14.0 Launcher3单层模式workspace中app列表页排序功能实现

1.概述 在14.0的定制化开发中,对于Launcher3的功能定制也是好多的,而对于单层app列表页来说排序功能的开发,也是常有的功能这就需要了解加载app数据的流程,然后根据需要进行排序就可以了,接下来就来实现这个功能 如图: 2. Launcher3单层模式workspace中app列表页排序功能…

8K样本在DeepSeek-R1-7B模型上的复现效果

7B Model and 8K Examples: Emerging Reasoning with Reinforcement Learning is Both Effective and Effic (notion.site) 港科大助理教授何俊贤的团队以Qwen2.5-Math-7B(基础模型)为起点,直接对其进行强化学习。整个过程中,没有…

四、自然语言处理_08Transformer翻译任务案例

0、前言 在Seq2Seq模型的学习过程中,做过一个文本翻译任务案例,多轮训练后,效果还算能看 Transformer作为NLP领域的扛把子,对于此类任务的处理会更为强大,下面将以基于Transformer模型来重新处理此任务,看…

MATLAB 生成脉冲序列 pulstran函数使用详解

MATLAB 生成脉冲序列 pulstran函数使用详解 目录 前言 一、参数说明 二、示例一 三、示例二 总结 前言 MATLAB中的pulstran函数用于生成脉冲序列,支持连续或离散脉冲。该函数通过将原型脉冲延迟并相加,生成脉冲序列,适用于信号处理和系统…

算法练习——滑动窗口

前言:滑动窗口的难点不在于怎么编写代码,而在于如何想到这题是用滑动窗口的算法去解决。其次滑动窗口的左端和右端在滑动时窗口内数据存在单调性。 一:长度最小的子数组 题目要求: 解题思路: 对于第一道滑动窗口算法…

Zabbix-监控SSL证书有效期

背景 项目需要,需要监控所有的SSL证书的有效期,因此需要自定义一个监控项 实现 创建自定义脚本 在Zabbix的scripts目录(/etc/zabbix/scripts/)下创建一个新的shell脚本check_ssl.sh,内容如下 #!/bin/bash time$(echo | openssl s_client…

VSCode中出现“#include错误,请更新includePath“问题,解决方法

1、出现的问题 在编写C程序时,想引用头文件但是出现如下提示: (1)首先检查要引用的头文件是否存在,位于哪里。 (2)如果头文件存在,在编译时提醒VSCode终端中"#include错误&am…

讯方·智汇云校华为授权培训机构的介绍

官方授权 华为授权培训服务伙伴(Huawei Authorized Learning Partner,简称HALP)是获得华为授权,面向公众(主要为华为企业业务的伙伴/客户)提供与华为产品和技术相关的培训服务,培养华为产业链所…

LabVIEW商业软件开发

在商业软件开发和仪器自动测试领域,LabVIEW以其图形化编程方式、高效的数据采集能力和强大的硬件集成优势,成为众多工程项目的核心开发工具。然而,商业软件的开发远不止编写代码和实现功能那么简单,尤其是在仪器自动测试领域&…