代码随想录算法训练营第十一天| 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

相关文章

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页