代码随想录算法训练营第十一天| 20. 有效的括号、1047. 删除字符串中的所有相邻重复项、150. 逆波兰表达式求值

本文主要是介绍代码随想录算法训练营第十一天| 20. 有效的括号、1047. 删除字符串中的所有相邻重复项、150. 逆波兰表达式求值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

20. 有效的括号

在这里插入图片描述

题目链接:20. 有效的括号
文档讲解:代码随想录
状态:so easy

思路: 使用栈,如果是左括号就入栈,如果是右括号则判断是否和栈顶括号匹配,如果匹配就出栈,否则判断遍历完字符串后栈中是否还有残留。

题解:

    public boolean isValid(String s) {if (s.length() % 2 != 0)return false;char[] chars = s.toCharArray();Deque<Character> stack = new ArrayDeque<>();for (char c : chars) {// 如果当前字符是开放括号,将其压入栈中if (c == '(' || c == '[' || c == '{') {stack.push(c);}// 如果当前字符是闭合括号,并且栈不为空且栈顶元素与当前闭合括号匹配// 则弹出栈顶元素,表示括号匹配成功else if (c == ')' && !stack.isEmpty() && stack.peek() == '(') {stack.poll();} else if (c == ']' && !stack.isEmpty() && stack.peek() == '[') {stack.poll();} else if (c == '}' && !stack.isEmpty() && stack.peek() == '{') {stack.poll();} else {return false;}}return stack.isEmpty();}

1047. 删除字符串中的所有相邻重复项

在这里插入图片描述

题目链接:1047. 删除字符串中的所有相邻重复项
文档讲解:代码随想录
状态:还行

思路: 使用栈,栈顶元素如果和即将入栈元素相同就出栈。

普通栈解法:

    public String removeDuplicates2(String s) {char[] chars = s.toCharArray();Deque<Character> stack = new ArrayDeque<>();for (char c : chars) {Character peek = stack.peek();if (peek != null && peek == c) {stack.poll();} else {stack.push(c);}}StringBuilder sb = new StringBuilder();while (!stack.isEmpty()) {sb.append(stack.poll());}return sb.toString();}

数组模拟栈 :

    public String removeDuplicates(String s) {// 将输入字符串转换为字符数组char[] cs = s.toCharArray();// 用于模拟栈的数组char[] stack = new char[s.length()];// 栈顶指针int top = -1;// 遍历输入字符串的每个字符for (char c : cs) {if (top >= 0 && stack[top] == c) {// 如果栈不为空且栈顶元素与当前字符相同,弹出栈顶元素top--;} else {// 否则,将当前字符压入栈stack[++top] = c;}}// 将栈中的字符组成字符串return new String(stack, 0, top + 1);}

双指针: 本质上和数组模拟栈的逻辑是一样的

public String removeDuplicates(String s) {char[] ch = s.toCharArray();int fast = 0;int slow = 0;while(fast < s.length()){// 直接用fast指针覆盖slow指针的值ch[slow] = ch[fast];// 遇到前后相同值的,就跳过,即slow指针后退一步,下次循环就可以直接被覆盖掉了if(slow > 0 && ch[slow] == ch[slow - 1]){slow--;}else{slow++;}fast++;}return new String(ch,0,slow);
}

150. 逆波兰表达式求值

在这里插入图片描述

题目链接:150. 逆波兰表达式求值
文档讲解:代码随想录
状态:还可以

思路: 逆波兰表达式一般使用栈,遇到运算符就将运算符前两个数拿出来做对应计算然后再入栈。

自带栈解法:

    public int evalRPN(String[] tokens) {Deque<Integer> stack = new ArrayDeque<>();for (String token : tokens) {if (!token.equals("+") && !token.equals("-") && !token.equals("*") && !token.equals("/")) {stack.push(Integer.valueOf(token));} else {int second = stack.pop(); // 出栈两个操作数int first = stack.pop();switch (token) {case "+":stack.push(first + second); // 将计算结果入栈break;case "-":stack.push(first - second);break;case "*":stack.push(first * second);break;case "/":stack.push(first / second);break;}}}return stack.pop();}

数组模拟栈:

class Solution {public int evalRPN(String[] tokens) {int[] stack = new int[tokens.length];int top = -1; // 栈顶指针,初始化为-1表示空栈for (String token : tokens) {if ("+-*/".contains(token)) {int b = stack[top--]; // 出栈两个操作数int a = stack[top--];stack[++top] = calculate(a, b, token); // 将计算结果入栈} else {stack[++top] = Integer.parseInt(token); // 将操作数入栈}}return stack[top]; // 返回栈顶元素即为最终结果}private int calculate(int a, int b, String operator) {switch (operator) {case "+":return a + b;case "-":return a - b;case "*":return a * b;case "/":return a / b;default:throw new IllegalArgumentException("Invalid operator: " + operator);}}
}

数组模拟栈的总结:

关键点在于:

  1. 定义目标类型的数组作为模拟栈;
  2. 初始化top为-1(表示一个空栈)
  3. 遍历元素:
    • 如果条件满足则出栈,top–
    • 如果不满足则入栈,++top

这篇关于代码随想录算法训练营第十一天| 20. 有效的括号、1047. 删除字符串中的所有相邻重复项、150. 逆波兰表达式求值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022583

相关文章

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

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

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

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav