一.栈 · stack

1.概念

:

  • 一种特殊的线性表 , 其只允许再固定的一段进行插入和删除元素操作 
  • 进行数据插入和删除操作的一段称为 栈顶  ; 另一端称为栈底
  • 栈中的数据元素遵循 先进后出 原则(LIFO)
  • 压栈 : 栈的插入操作叫做 进栈压栈入栈 , 入数据在栈顶
  • 出栈 : 栈的删除操作叫做 出栈 , 出数据在栈顶

2.栈的主要方法

方法功能
Stack()构造一个空的栈
E push(E e)将 e 入栈,并返回 e
E pop()将栈顶元素出栈并返回
E peek()获取栈顶元素
int size()获取栈中有效元素个数
boolean empty()检测栈是否为空
    public static void main(String[] args) {Stack<Integer> stack = new Stack<>();stack.push(11);stack.push(12);stack.push(13);stack.push(14);System.out.println(stack);System.out.println(stack.size());System.out.println(stack.peek());stack.pop();}

3.栈的模拟实现

Stack 继承了 Vector(动态顺序表)

import java.util.Arrays;public class MyStack {public int[] elem;public int usedSize;public MyStack(){this.elem = new int[10];}public boolean isFull(){return this.elem.length == usedSize;}//将 元素 val 入栈 , 并返回public void push(int val){if(isFull()){//判满this.elem = Arrays.copyOf(elem,elem.length*2);//满了则扩大为原来的两倍}this.elem[usedSize++] = val;//后置++ , 先使用usedSize , 再+1}public boolean empty(){return usedSize == 0;//判断是否为空 , 空返回true , 非空返回false}public int pop(){//将栈顶元素取出 , 并返回if(empty()){throw new EmptyStackException();}else{int val = elem[usedSize-1];usedSize--;return val;}}public int peek(){//获取栈顶元素if(empty()){throw new EmptyStackException();}else{return elem[usedSize];}}}
public class EmptyStackException extends RuntimeException{public EmptyStackException() {super();}public EmptyStackException(String message) {super(message);}
}
  • 测试:
public class Test {public static void main(String[] args) {MyStack myStack = new MyStack();myStack.push(11);myStack.push(12);myStack.push(13);myStack.push(14);System.out.println(myStack);//打印栈的元素System.out.println(myStack.pop());//打印栈顶的元素 , 并将栈顶元素取出System.out.println(myStack);System.out.println(myStack.peek());//打印栈顶的元素}
}

4.栈的应用场景

①改变元素序列

②将递归化为循环

// 递归方式
void printList(Node head) {if (null != head) {printList(head.next);System.out.print(head.val + " ");}
}// 循环方式
void printList(Node head) {if (null == head) {return;}Stack<Node> s = new Stack<>();// 将链表中的结点保存在栈中Node cur = head;while (null != cur) {s.push(cur);cur = cur.next;}// 将栈中的元素出栈while (!s.empty()) {System.out.print(s.pop().val + " ");}
}

括号匹配问题

题目:

  • 给定一个只包括 '('')''{''}''['']' 的字符串 s ,判断字符串是否有效。
  • 有效字符串需满足:
  • 左括号必须用相同类型的右括号闭合。
  • 左括号必须以正确的顺序闭合。
  • 每个右括号都有一个对应的相同类型的左括号
public boolean isValid(String s) {Stack<Character> stack = new Stack();for(int i = 0;i<s.length();i++){char c1 = s.charAt(i);if(c1 == '(' || c1 == '[' || c1 == '{'){stack.push(c1);}else {if(stack.empty()){return false;}char c2 = stack.peek();if(c1 == ')' && c2 == '('|| c1 == '}' && c2 == '{'|| c1 == ']' && c2 == '['){stack.pop();}else {return false;}}}if(!stack.empty()){return false;}return true;}

④栈的压入、弹出序列

题目:

  • 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序
  • 假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。
  • 0<=pushV.length == popV.length <=1000
  •  -1000<=pushV[i]<=1000
  •  pushV 的所有数字均不相同
        public boolean IsPopOrder (int[] pushV, int[] popV) {Stack <Integer> stack = new Stack<>();int j = 0;for (int i = 0; i < pushV.length; i++) {stack.push(pushV[i]);while(!stack.empty()&&j < popV.length&&stack.peek() == popV[j]){stack.pop();j++;}}return stack.empty() ;}

⑤逆波兰表达式求值

  • 中缀表达式求值

逆波兰表达式求值:

  • 将这些字符从左到右依次放到栈中
  • 其中数字放到栈中 , 遇到算数符号时 , 取出两个栈顶的元素
  • 其中最上方的元素作为运算符的左操作数,下一个元素作为右操作数 , 再把得到的结果放回栈中
  • 继续重复操作

题目:

给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。

请你计算该表达式。返回一个表示表达式值的整数。

注意:

  • 有效的算符为 '+''-''*' 和 '/' 。
  • 每个操作数(运算对象)都可以是一个整数或者另一个表达式。
  • 两个整数之间的除法总是 向零截断 。
  • 表达式中不含除零运算。
  • 输入是一个根据逆波兰表示法表示的算术表达式。
  • 答案及所有中间计算结果可以用 32 位 整数表示。
public boolean isoperation(String s){if(s.equals("+")||s.equals("-")||s.equals("*")||s.equals("/")){return true;}else {return false;}}public int evalRPN(String[] tokens) {Stack<Integer> stack = new Stack<>() ;for (String c:tokens) {if(!isoperation(c)){int x = Integer.parseInt(c);stack.push(x);}else {int val2 = stack.pop();int val1 = stack.pop();switch (c){case "+":stack.push(val1+val2);break;case "-":stack.push(val1-val2);break;case "*":stack.push(val1*val2);break;case "/":stack.push(val1/val2);break;}}}return stack.pop();}

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

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

相关文章

MySQL执行过程中如何选择最佳的执行路径

本篇文章介绍一个非常核心的数据库问题。MySQL 选择最佳执行路径&#xff08;即“查询优化”&#xff09;的过程是由其查询优化器&#xff08;Query Optimizer&#xff09; 完成的。 简单来说&#xff0c;优化器的目标是&#xff1a;在多种可能的执行方案中&#xff0c;选择一个…

【设计模式】从游戏角度开始了解设计模式 --- 抽象工厂模式

永远记住&#xff0c;你的存在是有意义的&#xff0c; 你很重要&#xff0c; 你是被爱着的&#xff0c; 而且你为这个世界带来了无可取代的东西。 -- 麦克西 《男孩、鼹鼠、狐狸和马》-- 从零开始了解设计模式抽象工厂模式抽象工厂模式 今天我们一起来探究抽象工厂模式&#x…

tensorflow.js 使用场景

TensorFlow.js (简称 TF.js) 是一个利用 WebGL 和 Node.js 在浏览器和服务器端进行机器学习模型训练和部署(推理)的 JavaScript 库。它的核心价值在于将机器学习的能力带入了 Web 开发者和 JavaScript 生态的领域。 其主要应用场景可以分为以下几大类: 一、在浏览器中直接进…

详解mcp以及agen架构设计与实现

文章目录1.MCP概念2.MCP服务端主要能力3.MCP技术生态4.MCP与Function call区别5.MCP生命周期6.MCP java SDK7.MCP应用场景8.基于springAIollma阿里qianwenmcp设计私有AIAgent应用实现9.AI java项目落地技术选型10.构建AI Agent四大模块11.LLM(大模型)与MCP之间关系12.A2A、MCP、…

六级第一关——下楼梯

上目录&#xff1a; 目录 题目描述 输入格式 输出格式 输入输出样例 说明/提示 一、DP的意义以及线性动规简介 在一个困难的嵌套决策链中&#xff0c;决策出最优解。 二、动态规划性质浅谈 三、子序列问题 &#xff08;一&#xff09;一个序列中的最长上升子序列&am…

【Linux基础】Linux系统配置IP详解:从入门到精通

目录 1 Linux网络配置概述 2 网卡配置文件位置和命名规则 2.1 配置文件位置 2.2 网卡命名规则 2.3 配置文件命名示例 3 网卡配置文件详解 3.1 主要参数说明 4 Linux系统配置IP步骤 4.1 DHCP动态配置 4.2 静态IP配置 5 Linux网络配置流程 5.1 网络配置流程 5.2 网卡…

C语言sprintf的高效替代方案

C语言的sprintf和snprintf将变量格式化输出到内存buffer&#xff0c;其功能强大&#xff0c;用起来很方便。但sprintf系列函数的运行效率低下&#xff0c;主要包括四方面的原因&#xff1a;格式字符串解析、变参处理、locale&#xff08;本地化&#xff09;支持和通用&#xff…

【知识堂】制造业与物流数字化全景图:系统缩写大全与专业名词速查手册

前言在制造业和物流行业的数字化转型过程中&#xff0c;我们经常会接触到大量的 系统缩写&#xff08;如 ERP、MES、WMS…&#xff09;和 专业名词&#xff08;如 AGV、BOM、LOT…&#xff09;。 这些缩写往往让刚入行的人“一头雾水”&#xff0c;即使是有经验的从业者&#x…

利用JSONCrack与cpolar提升数据可视化及跨团队协作效率

文章目录前言1. 在Linux上使用Docker安装JSONCrack2. 安装Cpolar内网穿透工具3. 配置JSON Crack界面公网地址4. 远程访问 JSONCrack 界面5. 固定 JSONCrack公网地址前言 JSONCrack 是一款功能强大的开源数据可视化工具&#xff0c;专为解析和展示复杂的 JSON、XML 等结构化数据…

CANoe入门之一 CANoe功能概述

01 CANoe功能概述 CANoe软件在汽车电子领域被广泛应用。 CANoe软件的全称是CAN Open Environment&#xff0c;它是一个专业的系统级总线和ECU仿真、分析、开发、测试工具。支持ECU或总线网络开发从需求分析到系统实现的全过程&#xff0c;包括模型创建、仿真、测试、诊断及通信…

项目管理核心八项(软件篇)

2025年09月11日23:50:33&#xff1a;进来常思&#xff0c;写代码也五六年了&#xff0c;后面的路该何去何从呢&#xff1f; 项目管理核心八项一、项目管理之“建立开发人员 backup 机制”二、待补充一、项目管理之“建立开发人员 backup 机制” “建立开发人员 backup 机制” 是…

springboot redisson 分布式锁入门与实战

Spring Boot3 Redisson 项目地址 https://gitee.com/supervol/loong-springboot-study &#xff08;记得给个start&#xff0c;感谢&#xff09; Redisson 介绍 在分布式系统中&#xff0c;多节点部署的应用对共享资源&#xff08;如数据库记录、缓存键、文件&#xff09;的…

使用 Tkinter + Requests 实现地理信息安全系统学习时长助手

✨重磅&#xff01;盹猫的个人小站正式上线啦&#xff5e;诚邀各位技术大佬前来探秘&#xff01;✨ 这里有&#xff1a; 硬核技术干货&#xff1a;编程技巧、开发经验、踩坑指南&#xff0c;带你解锁技术新姿势&#xff01;趣味开发日常&#xff1a;代码背后的脑洞故事、工具…

构建一个优雅的待办事项应用:现代JavaScript实践

构建一个优雅的待办事项应用&#xff1a;现代JavaScript实践本文将介绍如何使用现代JavaScript&#xff08;ES6&#xff09;和DOM操作创建一个功能完整的待办事项应用&#xff0c;无需任何外部库或框架。功能概述添加新任务标记任务为完成/未完成编辑任务内容删除任务过滤任务&…

【数据可视化-111】93大阅兵后的军费开支情况———2024年全球军费开支分析:用Python和Pyecharts打造炫酷可视化大屏

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…

3.2.Maven-概述-介绍安装

一.介绍&#xff1a;二.安装&#xff1a;Maven的安装比较简单&#xff0c;因为他是绿色版的软件&#xff0c;官方给我们提供Maven的安装包就是一个zip压缩包&#xff0c;在进行Maven安装以及配置的时候&#xff0c;主要进行如下4步操作&#xff1a;第一步&#xff1a;把官方提供…

Kafka面试精讲 Day 14:集群扩容与数据迁移

【Kafka面试精讲 Day 14】集群扩容与数据迁移 在“Kafka面试精讲”系列的第14天&#xff0c;我们将深入探讨 Kafka 运维中最关键的操作之一&#xff1a;集群扩容与数据迁移。随着业务增长&#xff0c;原始 Kafka 集群可能面临磁盘不足、吞吐瓶颈或节点负载不均等问题&#xff…

字节一面 面经(补充版)

什么是RabbitMQ&#xff0c;特点是什么怎么理解保障消息的一致性String、StringBuffer、StringBuilder解释一下线程安全先操作数据库再删缓存还是先删缓存再操作数据库这种办法能杜绝数据不一致问题吗解释一下AOP介绍Redis的特点&#xff08;Redis比较快&#xff09;Redis为什么…

【MFC】对话框属性:Absolute Align(绝对对齐)

前言 本文介绍对话框属性中的Absolute Align(绝对对齐)&#xff0c;同时给出相关示例便于理解。 目录1 位置2 详解3 示例1 位置 首先介绍一下这个属性在哪里。 在资源视图中双击对话框节点&#xff0c;打开该对话框&#xff1b; 鼠标右键工作区空白处&#xff0c;单击属性&…

【从0开始学习Java | 第17篇】集合(中-Set部分)

文章目录Java集合之Set&#xff1a;无序不重复的元素容器一、Set接口的核心特性二、常用实现类及底层原理1. HashSet&#xff1a;基于哈希表的高效实现2. LinkedHashSet&#xff1a;保留插入顺序的哈希实现3. TreeSet&#xff1a;基于红黑树的排序实现三、实现类对比与选择建议…