代码随想录刷题笔记(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,一经查实,立即删除!

相关文章

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 年全球范围内利用虚拟货币进行诈骗…

Radzen Blazor Studio 脚手架框架解读

背景 组织管理管理准备使用Blazor这个工具实现&#xff0c;因为其有对应的 scaffold 脚手架&#xff0c;先构建数据库&#xff0c;然后通过向导&#xff0c;生成CRUD以及对应的接口&#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;因为无重复字符的最长子串是…

牛客周赛 Round 28 F

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

多线程并发与并行

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

python爬虫之线程与多进程知识点记录

一、线程 1、概念 线程 在一个进程的内部&#xff0c;要同时干多件事&#xff0c;就需要同时运行多个“子任务”&#xff0c;我们把进程内的这些“子任务”叫做线程 是操作系统能够进行运算调度的最小单位。它被包含在进程之中&#xff0c;是进程中的实际运作单位。一条线程指…

DAY01_Spring—Spring框架介绍IOCSpring工厂模式

目录 1 什么是框架2 Spring框架2.1 Spring介绍2.2 MVC模型说明2.3 IOC思想2.3.1 问题说明2.3.2 IOC说明 3 Spring IOC具体实现3.1 环境准备3.1.1 关于JDK说明3.1.2 检查JDK环境配置 3.2 创建项目3.3 关于Maven 命令3.3.1 install 命令3.3.2 clean 命令 3.4 添加jar包文件3.4.1 …

flutter使用getx进行数据状态管理,实现页面响应式

无论是什么样的应用&#xff0c;都还是需要最基础的数据来支撑的&#xff0c;而且不同的页面之间可能需要共享数据状态&#xff0c;这就显得数据状态管理非常有必要了。因为我这里使用了get依赖库&#xff0c;所以就可以直接在项目中使用getx来管理状态&#xff0c;不想再使用别…

服务器机房上架交付流程

服务器上架交付 服务器到货验收后&#xff0c;会进行机房机房上架&#xff0c;完成重装系统、网络配置后交付使用 1、到货验收 采购服务器到货后&#xff0c;会联合多部门进行SN、配置、数量等多方面验收&#xff0c;如数量是否匹配&#xff0c;配置是否相符等也会拆开机箱看看…

Python基础知识:整理10 异常相关知识

1 异常的捕获 1.1 基础写法 """基本语法&#xff1a;try:可能发生错误的代码except:如果出现异常&#xff0c;将执行的代码""" try:fr open("D:/abc.txt", "r", encoding"utf-8") except:print("出现异常…

APM传感器校准

文章目录 前言一、校准加速度计二、校准罗盘三、校准陀螺仪四、校平地平线 前言 固件&#xff1a;rover 4.2.3 地面站&#xff1a;独家汉化版QGC 一、校准加速度计 点击左上角软件图标-》载具设置-》传感器-》加速度计 飞控方向默认为None即可&#xff0c;点击确定 点击确…

德语怎么翻译,中文翻译成德文有何要求?

近年来&#xff0c;随着中德之间的贸易往来日益频繁&#xff0c;德语翻译需求在市场上持续升温。那么&#xff0c;如何做好德语翻译&#xff0c;特别是将中文翻译成德文需要注意哪些要求呢&#xff1f; 首先&#xff0c;深入理解中文原文的语境和含义至关重要。中文含蓄且抽象&…

存储的基本架构

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、存储的需求背景二、自下而上存储架构总结 一、存储的需求背景 1、人的身份信息需要存储 这种信息可以用关系型数据库&#xff0c;例如mysql&#xff0c;那种表…

第十二章 Java内存模型与线程(二)

文章目录 12.4 Java与线程12.4.1 线程的实现12.4.2 Java线程调度12.4.3 状态转换 12.4 Java与线程 12.4.1 线程的实现 实现线程主要有三种方式&#xff1a;使用内核线程实现&#xff08;1&#xff1a; 1 实现&#xff09;&#xff0c;使用用户线程实现&#xff08;1&#xff…