算法练习笔记——栈的常用方法以及算法练习

news/2024/11/19 18:34:31/

栈学习

  • 常用方法介绍
  • 力扣练习
    • 力扣 20. 有效的括号
    • 力扣 32. 最长有效括号

常用方法介绍

     Stack<Character> characters = new Stack<>();//判断栈是否为空boolean empty = characters.empty();//将a压入栈底,同时也返回aCharacter push = characters.push('a');//返回栈顶的元素但是并不会删除它Character peek = characters.peek();//返回栈顶的元素,并将它删除Character pop = characters.pop();//在堆栈中搜索a,如果发现了,则返回它相对于栈顶//的偏移量。否则,返回-1。int search = characters.search('a');boolean empty1 = characters.isEmpty();

力扣练习

力扣 20. 有效的括号

在这里插入图片描述
解法一

class Solution {Stack<Character> characters = new Stack<>();public boolean isValid(String s) {char[] chars = s.toCharArray();for(int i=0;i<s.length();i++){if(chars[i]=='(') characters.push(')');else if(chars[i]=='{') characters.push('}');else if(chars[i]=='[') characters.push(']');else if(characters.isEmpty()||chars[i]!=characters.pop()) return false;}return characters.isEmpty();                                                                         }
}

思路:
利用到了栈的后入先出的特性
利用左半边的进行判断。如果与之对应就将对应的入栈,下次如果不是左边的,就将栈里面的与之比较相同出栈。

力扣 32. 最长有效括号

在这里插入图片描述

class Solution {public int longestValidParentheses(String s) {int maxans=0;Stack<Integer> stack = new Stack<>();stack.push(-1);if(s.length()==0||s.length()==1){return 0;}char[] chars = s.toCharArray();for(int i=0;i<s.length();i++){if(chars[i]=='(') stack.push(i);else{stack.pop();if(stack.isEmpty()){stack.push(i);}else{maxans = Math.max(maxans, i-stack.peek());}}}return maxans;}
}

思路分析:
首先我的第一反应是用栈,当遇到(时,将其入栈,遇到)时将栈顶元素弹出,这样可以实现()的匹对
但是需要的是找出记录出长度和找出最长字符串
我们先定义一个maxans 即最长字符串
接下来我们需要找出最长字符串
我们可以先将字符串转为数组,利用其元素下标,求出最长字符串:
思路就是我们可以将元素下标入栈,记录下最后一个不匹配的元素下标,这样两次做差就可以求出,在每一次都用数学函数找出最大的数据记录
由于第一次没有元素我们可以先将-1入栈


http://www.ppmy.cn/news/18832.html

相关文章

02 |「数据结构、逻辑结构、物理结构」基本概念简析

前言 前言&#xff1a;简析数据结构、逻辑结构、物理结构。 文章目录前言一、数据结构1. 简介2. 数据3. 结构4. 分析5. 分类1&#xff09;线性结构&#xff08;线性表&#xff09;2&#xff09;树结构3&#xff09;图结构二、逻辑结构与物理结构1. 为什么要有逻辑结构和物理结构…

十六进制转八进制+超大数据处理(蓝桥杯基础练习C/C++)

目录 1 题目要求 2 代码 2.1 以十进制为媒介&#xff08;不可行&#xff09; 2.2 以二进制为媒介 3 可能会遇到的难点 4 结论 5 延伸 5.1 超大数据阶乘 5.2 超大数据加法 5.3 以十进制为媒介的进制转换 1 题目要求 2 代码 2.1 以十进制为媒介&#xf…

深信服行为感知命令执行漏洞

深信服行为感知命令执行漏洞1.深信服行为感知漏洞1.1.漏洞描述1.2.漏洞影响1.3.漏洞复现1.3.1.登录页面1.3.2.构建漏洞URL1.3.2.1.查询IP地址1.3.2.2.查询当前目录下文件1.深信服行为感知漏洞 1.1.漏洞描述 深信服 行为感知系统c.php远程命令执行漏洞&#xff0c;使用与EDR相同…

创建者模式-原型模式

1.概述 用一个已经创建的实例作为原型&#xff0c;通过复制该原型对象来创建一个和原型对象相同的新对象 2.结构 原型模式包含如下角色&#xff1a; 抽象原型类&#xff1a;规定了具体原型对象必须实现的的 clone() 方法。具体原型类&#xff1a;实现抽象原型类的 clone() …

liunx centos9安装nodejs并搭建vue 图文详解手把手教程

首先nodjs的官网找到liunx的安装包 https://nodejs.org/en/download/ 这里不推荐用源码安装&#xff0c;因为实在太慢&#xff0c;我安装时一下在不停安装连续15分钟都还在跑就是不知道什么原因 解压包 tar -xvf /root/node-v18.13.0-linux-x64.tar.xz设置全局 -s后面地址就是…

07 | 应届生身份为什么重要?只有一次

文章目录一、应届生身份的划分1、企业角度2、学校角度3、国家角度二、应届生身份的重要性1、国考/省考2、企业招聘3、落户政策4、签约保障一、应届生身份的划分 国家统一招生的高校毕业生离校时&#xff0c;和在择业期内&#xff08;国家规定择业期为两年&#xff09;未落实工…

Java基础之《netty(29)—自定义协议解决TCP粘包拆包》

一、TCP粘包和拆包解决方案 1、使用自定义协议 编解码器&#xff0c;来解决。 2、关键就是要解决&#xff0c;服务器端每次读取数据长度的问题。这个问题解决&#xff0c;就不会出现服务器多读或少读数据的问题&#xff0c;从而避免TCP粘包、拆包。 二、具体示例 1、要求客…

Kettle(4):excel数据抽取到mysql

1 准备工作 1.1 准备Excel文件 我这边直接使用上一篇导出的excel:file_user.xls 1.2 创建数据库 在mysql中创建数据库 1.3 在kettle中加载MySQL驱动 Kettle要想连接到MySQL&#xff0c;必须要安装一个MySQL的驱动&#xff0c;就好比我们装完操作系统要安装显卡驱动一样。加…