代码随想录刷题笔记(DAY11)

今日总结:继续准备期末,今天的算法题目比较简单,晚上看看能不能再整理一篇前端的笔记。

Day 11

01. 有效的括号(No. 20)

题目链接

代码随想录题解

1.1 题目

给定一个只包括 '('')''{''}''['']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

示例 1:

输入:s = “()”
输出:true

示例 2:

输入:s = “()[]{}”
输出:true

示例 3:

输入:s = “(]”
输出:false

提示:

  • 1 <= s.length <= 104
  • s 仅由括号 '()[]{}' 组成
1.2 笔记

还记得刚开始刷力扣的时候看到这个题一点思路没有,现在学习了栈的知识,发现这道题通过栈可以很轻松的解决。

为什么会想到用栈呢?

栈是“先进后出”的数据结构,并且可以方便的弹出,在这种验证匹配的题目非常好用,这道题先来单独看一个右括号,如果在后面立刻找到了对应的左括号那就可以直接弹出,但如果碰到的是另一个右括号,

如果存在对应的话,那这第二个右括号肯定要比第一个先找到它的左括号即先弹出。

比如:{{}} 在遍历过程中第一个 { 要比第二个 { 晚找到它对应的 }

这正好符合了先进后出的特点。

所以想到了一个思路:我们将这个 String 转化为 char[] 从前向后依次遍历这个数组,如果遇到 右括号 就将其存到栈里,遇到左括号我们就检查栈中的 栈顶元素 是否和这个括号匹配,按照上面的规律,栈顶元素一定是 最先 找到对应的左括号的。

由此引出了三个错误的情况:

  1. 我们遍历到左括号的时候发现栈中没有元素,即左括号多出来了。
  2. 发现栈顶元素和左括号中的元素不对应
  3. 遍历完成栈中仍有元素,右括号多出来了

只要在循环中去处理这几个问题,这道题就解决了。

1.3 代码
class Solution {Stack<Character> s = new Stack<>(); // 存放左括号的栈HashMap<Character, Integer> left = new HashMap<>(); // 左括号HashMap<Character, Integer> right = new HashMap<>(); // 右括号public boolean isValid(String s) {// 初始化 Map,key 为括号,value 为给它的分组left.put('(', 1);left.put('{', 2);left.put('[', 3);right.put(')', 1);right.put('}', 2);right.put(']', 3);char[] charArray = s.toCharArray();return check(charArray);}public boolean check(char[] charArray) {for (char c : charArray) {if (left.containsKey(c)) {// 右括号直接放入栈中s.push(c);} else {Integer key = right.get(c); // 得到它的组号// 错误情况二:左括号多了if (s.empty()) {return false;}// 错误情况一:左右不匹配if (!left.get(s.pop()).equals(key)) {return false;}}}// 错误情况三:右括号多了if (!s.empty()) {return false;}return true;}
}

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

题目链接

代码随想录题解

2.1 题目

给出由小写字母组成的字符串 S重复项删除操作会选择两个相邻且相同的字母,并删除它们。

在 S 上反复执行重复项删除操作,直到无法继续删除。

在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。

示例:

输入:“abbaca”
输出:“ca”
解释:
例如,在 “abbaca” 中,我们可以删除 “bb” 由于两字母相邻且相同,这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 “aaca”,其中又只有 “aa” 可以执行重复项删除操作,所以最后的字符串为 “ca”。

提示:

  1. 1 <= S.length <= 20000
  2. S 仅由小写英文字母组成。
2.2 笔记

在刷章节性的题目的时候,最重要的是总结什么时候要使用这种方法求解,因为我们已经知道这道题一定可以用这类方法作答。

栈的题目我们要检查求解的内容是否可以通过先进后出的特质来求解,这道题和上面那题一样是找对应,我们仍然可以得到:

先入栈的肯定比后入栈的后找到对应

接下来就是处理删除的情况了,我首先想到的是和上一道题那样把 遍历过 的存到栈中,遇到相邻的就删除,但删除字符串的时间复杂度很高,而且比较难以操作。

所以换一个想法,可以用栈来存储最终的结果,我们遍历字符串的时候依次将元素存入栈中,如果遇到了相同的元素代表可以删除,就将这个元素弹出,完成遍历后栈中存储的就是需要的结果字符串:

在这里插入图片描述

但注意栈的弹出顺序和输入顺序相反,我们最后要处理这个顺序问题。

2.3 代码
class Solution {// 初始化使用的队列Stack<Character> stack =  new Stack<>();public String removeDuplicates(String s) {char[] charArray = s.toCharArray();for (char c : charArray) {if (stack.isEmpty()) {// 为空则直接放入stack.push(c); } else {if (stack.peek() == c) {// 如果相同则弹出栈内的元素再进行下一个循环stack.pop();} else {stack.push(c);}}}char[] res = new char[stack.size()];int length = stack.size() - 1;// 倒序填充结果数组,处理逆序情况while (!stack.empty()) {res[length] = stack.pop();length--;}return String.valueOf(res);       }
}

03. 逆波兰表达式(No. 150)

题目链接

代码随想录题解

3.1 题目

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

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

注意:

  • 有效的算符为 '+''-''*''/'
  • 每个操作数(运算对象)都可以是一个整数或者另一个表达式。
  • 两个整数之间的除法总是 向零截断
  • 表达式中不含除零运算。
  • 输入是一个根据逆波兰表示法表示的算术表达式。
  • 答案及所有中间计算结果可以用 32 位 整数表示。

示例 1:

输入:tokens = [“2”,“1”,“+”,“3”,“*”]
输出:9
解释:该算式转化为常见的中缀算术表达式为:((2 + 1) * 3) = 9

示例 2:

输入:tokens = [“4”,“13”,“5”,“/”,“+”]
输出:6
解释:该算式转化为常见的中缀算术表达式为:(4 + (13 / 5)) = 6

示例 3:

输入:tokens = [“10”,“6”,“9”,“3”,“+”,“-11”,““,”/“,””,“17”,“+”,“5”,“+”]
输出:22
解释:该算式转化为常见的中缀算术表达式为:
((10 * (6 / ((9 + 3) * -11))) + 17) + 5
= ((10 * (6 / (12 * -11))) + 17) + 5
= ((10 * (6 / -132)) + 17) + 5
= ((10 * 0) + 17) + 5
= (0 + 17) + 5
= 17 + 5
= 22

提示:

  • 1 <= tokens.length <= 104
  • tokens[i] 是一个算符("+""-""*""/"),或是在范围 [-200, 200] 内的一个整数

逆波兰表达式:

逆波兰表达式是一种后缀表达式,所谓后缀就是指算符写在后面。

  • 平常使用的算式则是一种中缀表达式,如 ( 1 + 2 ) * ( 3 + 4 )
  • 该算式的逆波兰表达式写法为 ( ( 1 2 + ) ( 3 4 + ) * )

逆波兰表达式主要有以下两个优点:

  • 去掉括号后表达式无歧义,上式即便写成 1 2 + 3 4 + * 也可以依据次序计算出正确结果。
  • 适合用栈操作运算:遇到数字则入栈;遇到算符则取出栈顶两个数字进行计算,并将结果压入栈中
3.2 笔记

这道题相信曾经做过用栈实现计算器的朋友肯定不陌生,这道题相当于用栈实现计算器的简化版本,因为不用考虑运算符的优先级,逆波兰表达式的顺序就代表了计算的次序。

如何通过栈来实现计算呢?

将数字一个一个压入栈,当遇到运算符的时候从栈中弹出数字,计算完成后再压入栈,代替原本的两个数字去参与运算,之后再去寻找下一个运算符。

因为传入的是字符串,所以我们要考虑如何判断是数字还是运算符,判断是否是数字要分为三种情况:

  1. 仅有一位的数字
  2. 多位的数字
  3. 负数

仅有一位的数字可以通过 s.charAt(0) 来判断是否属于0 - 9 负数和多位的数字 s.charAt(1) 来判断

3.3 代码
class Solution {Stack<Integer> stack = new Stack<>();ArrayList<String> num = new ArrayList<>();public int evalRPN(String[] tokens) {// 用来判断是否为数字num.add("0");num.add("1");num.add("2");num.add("3");num.add("4");num.add("5");num.add("6");num.add("7");num.add("8");num.add("9");return doCount(tokens);}public int doCount(String[] tokens) {for (String s : tokens) {if (isNum(s)) {stack.push(Integer.valueOf(s));} else {Integer b = stack.pop();Integer a = stack.pop();stack.add(doOperator(a, b, s));}}return stack.pop();}public int doOperator(Integer a, Integer b, String operator) {// 对取出来的内容进行计算return switch (operator) {case "+" -> a + b;case "-" -> a - b;case "*" -> a * b;default -> a / b;};}// 判断是否是数字public boolean isNum(String s) {if (s.length() == 1) {return num.contains(String.valueOf(s.charAt(0)));} else if (s.length() >= 2) {return num.contains(String.valueOf(s.charAt(0))) ||num.contains(String.valueOf(s.charAt(1)));} else {return false;}      }
}

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

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

相关文章

Python Data Structures: Dictionary, Tuples

目录 Chapter9 Dictionary1. list and dictionary2. 修改值&#xff1a;3. 计算名字出现次数4. get()5. Dictionary and Files6. Retrieving lists of keys and values7.items()&#xff1a;产生tuples8.计算文件中的名字次数最大值 Chapter10 Tuples1. Tuples Are Like Lists2…

Android-常用数据结构和控件

HashMap 的原理 HashMap 的内部可以看做数组链表的复合结构。数组被分为一个个的桶(bucket)。哈希值决定了键值对在数组中的寻址。具有相同哈希值的键值对会组成链表。需要注意的是当链表长度超过阈值(默认是8)的时候会触发树化&#xff0c;链表会变成树形结构。 把握HashMap的…

5 - 声明式事务

传统事务流程&#xff1a; Connection connection JdbcUtils.getConnection(); try {//1. 先设置事务不要自动提交connection.setAutoCommit(false);//2. 进行各种 crud//多个表的修改&#xff0c;添加 &#xff0c;删除select from 商品表 > 获取价格//修改用户余额updat…

“确定要在不复制其属性的情况下复制此文件?”解决方案(将U盘格式由FAT格式转换为NTFS格式)

文章目录 1.问题描述2.问题分析3.问题解决3.1 方法一3.2 方法二3.3 方法三 1.问题描述 从电脑上复制文件到U盘里会出现“确定要在不复制其属性的情况下复制此文件&#xff1f;”提示。 2.问题分析 如果这个文件在NTFS分区上&#xff0c;且存在特殊的安全属性。那么把它从NT…

请查收“链上天眼”2023年成绩单

1月10日是中国人民警察节&#xff0c;是一份责任&#xff0c;更一份安心&#xff0c;随着科技的发展&#xff0c;链上安全领域的技术与工具不断更新迭代&#xff0c;更加安全的Web3世界正在构建。 根据欧科云链安全团队统计&#xff0c;2023 年全球范围内利用虚拟货币进行诈骗…

采购申请检查并警告提示

设置&#xff1a;采购申请检查并警告提示 增强&#xff1a;MEREQ001 EXIT_SAPLMEREQ_005 &--------------------------------------------------------------------- *& 包含 ZXM02U05 &--------------------------------------------------------------------- …

Radzen Blazor Studio 脚手架框架解读

背景 组织管理管理准备使用Blazor这个工具实现&#xff0c;因为其有对应的 scaffold 脚手架&#xff0c;先构建数据库&#xff0c;然后通过向导&#xff0c;生成CRUD以及对应的接口&#xff0c;那么有必要看一下&#xff0c;其内部的代码结构是什么样的。 结构 接口层 有两类…

L1-024 后天(Java)

如果今天是星期三&#xff0c;后天就是星期五&#xff1b;如果今天是星期六&#xff0c;后天就是星期一。我们用数字1到7对应星期一到星期日。给定某一天&#xff0c;请你输出那天的“后天”是星期几。 输入格式&#xff1a; 输入第一行给出一个正整数D&#xff08;1 ≤ D ≤…

布隆过滤器原理(易理解版)

当我们说布隆过滤器时&#xff0c;可以将其想象成一个特殊的盒子&#xff0c;这个盒子可以判断某个东西是否在里面。但是&#xff0c;这个盒子并不存储实际的东西&#xff0c;而是用一些特殊的方法来判断。 盒子&#xff08;位数组&#xff09;&#xff1a; 有一个盒子&#xf…

Oracle sql sum函数返回null,默认值0

在Oracle SQL中&#xff0c;当你使用SUM函数对一组值进行求和时&#xff0c;如果这组值中包含NULL&#xff0c;那么SUM函数将忽略这些NULL值&#xff0c;并返回非NULL值的总和。 如果你希望在SUM函数返回NULL时有一个默认值&#xff0c;你可以使用COALESCE或NVL函数。 使用CO…

深度学习烦人的基础知识(1)---@在bash中的作用---positional parameter详解

文章目录 序Positional parameter练习题 Special parameter练习题 序 深度学习&#xff0c;反展到现在&#xff0c;真的是要融会贯通很多东西。遇到便补吧&#xff01; 想直接知晓答案的&#xff0c;请到最后一个练习题&#xff0c;想补基础知识的&#xff0c;请按照顺序阅读…

Python——for循环的嵌套

用Python坚持表白一百天&#xff0c;每天都送10朵花&#xff0c;一百天表白成功&#xff01; i1 for i in range(1,101):print(f"今天是表白的第{i}天&#xff0c;坚持ing")for j in range(1,11):print(f"送给你第{j}朵玫瑰花")print("小美我喜欢你&…

Hive 的 安装与使用

目录 1 安装 MySql2 安装 Hive3 Hive 元数据配置到 MySql4 启动 Hive5 Hive 常用交互命令6 Hive 常见属性配置 Hive 官网 1 安装 MySql 为什么需要安装 MySql? 原因在于Hive 默认使用的元数据库为 derby&#xff0c;开启 Hive 之后就会占用元数据库&#xff0c;且不与其他客户…

Mindspore 公开课 - prompt

prompt 介绍 Fine-Tuning to Prompt Learning Pre-train, Fine-tune BERT bidirectional transformer&#xff0c;词语和句子级别的特征抽取&#xff0c;注重文本理解Pre-train: Maked Language Model Next Sentence PredictionFine-tune: 根据任务选取对应的representatio…

算法通关村第十六关—滑动窗口经典问题(白银)

滑动窗口经典问题 一、最长子串专题 1.1 无重复字符的最长子串 LeetCode3给定一个字符串s&#xff0c;请你找出其中不含有重复字符的最长子串的长度。例如&#xff1a; 输入&#xff1a;s"abcabcbb" 输出&#xff1a;3 解释&#xff1a;因为无重复字符的最长子串是…

【Java万花筒】数据之舞:Java数据库连接与操作库全景视角

数据库连接与操作&#xff1a;Java 应用开发者的综合指南 前言 随着Java应用的不断发展&#xff0c;数据库连接与操作成为关键技能之一。本文将深入探讨主流Java库&#xff0c;涵盖了JDBC、Hibernate、MyBatis、Spring Data JPA、Apache Commons DBUtils、JOOQ以及Querydsl。…

牛客周赛 Round 28 F

以后需要使用map&#xff0c;set进行二分&#xff0c;并且需要知道二分位置的信息时&#xff0c;不妨考虑使用树状数组进行维护 因为简单版本保证了每个数都为正整数&#xff0c;所以前缀和保证了一定的递增的&#xff0c;即有序的&#xff0c;那么考虑固定左端点&#xff0c;去…

多线程并发与并行

&#x1f4d1;前言 本文主要是【并发与并行】——并发与并行的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304;每日一句&…

自动化测试理论(1)—概述需要掌握的内容

要在自动化测试领域取得成功&#xff0c;需要掌握一系列技能和概念。以下是一些关键的内容&#xff1a; 编程语言&#xff1a; 了解并精通至少一种编程语言&#xff0c;如Python&#xff0c;Java&#xff0c;JavaScript等。编写自动化测试脚本通常需要编程技能。 自动化测试框…

SpringBoot3

有用的新特性 JDK8-19 新增了不少新特性&#xff0c;这里我们把实际常用的新特性&#xff0c;给大家介绍一下。包括以下几个方面&#xff1a; Java RecordSwich 开关表达式Text Block 文本块var 声明局部变量sealed 密封类 Java14 中预览的新特性叫做 Record &#xff0c;在…