代码随想录刷题笔记(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.mfbz.cn/a/315205.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AMEYA360报导:瑞萨宣布收购Transphorm,大举进军GaN

全球半导体解决方案供应商瑞萨电子与全球氮化镓(GaN)功率半导体供应商Transphorm, Inc.(以下“Transphorm”)于今天宣布双方已达成最终协议&#xff0c;根据该协议&#xff0c;瑞萨子公司将以每股5.10美元现金收购Transphorm所有已发行普通股&#xff0c;较Transphorm在2024年1…

XYplorer:双栏多标签文件资源管理器的高效选择

在文件管理的世界中&#xff0c;效率和便捷性是用户追求的关键。XYplorer作为一款专为Windows设计的文件资源管理器&#xff0c;以其独特的双栏多标签浏览、强大的文件搜索功能、以及高度可定制的界面&#xff0c;为用户提供了一种全新的文件管理体验。 XYplorer&#xff1a;速…

SpringMVC文件上传(CommonsMultipartResolver)

以上传一个图片为例 添加依赖 <!--文件上传--> <dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.1</version> </dependency> 配置文件上传解析器 <…

用C语言采集亚马逊amazon产品数据

上一篇文章我是用C写的一个爬取亚马逊的爬虫程序&#xff0c;相信大家已经看过了&#xff0c;这次呢&#xff0c;我依然使用C语言来写一个爬虫&#xff0c;大体上思路是和之前一样&#xff0c;只是支持的库以及语法有些区别&#xff0c;具体的呢我会一一解释出来&#xff0c;方…

利用Qt输出XML文件

使用Qt输出xml文件 void PixelConversionLibrary::generateXML() {QFile file("D:/TEST.xml");//创建xml文件if (!file.open(QIODevice::WriteOnly | QIODevice::Text))//以只写方式&#xff0c;文本模式打开文件{qDebug() << "generateXML:Failed to op…

stable diffusion使用相关

IP Adapter&#xff0c;我愿称之它为SD垫图 IP Adapter是腾讯lab发布的一个新的Stable Diffusion适配器&#xff0c;它的作用是将你输入的图像作为图像提示词&#xff0c;本质上就像MJ的垫图。 IP Adapter比reference的效果要好&#xff0c;而且会快很多&#xff0c;适配于各种…

互联网加竞赛 基于大数据的股票量化分析与股价预测系统

文章目录 0 前言1 课题背景2 实现效果3 设计原理QTChartsarma模型预测K-means聚类算法算法实现关键问题说明 4 部分核心代码5 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于大数据的股票量化分析与股价预测系统 该项目较为新颖…

学习笔记-mysql基础(DDL,DML,DQL)

一.DDL DDL,Data Definition Language,数据库定义语言,该语言包括以下内容: 对数据库的常用操作对表结构的常用操作修改表结构 1.对数据库的常用操作 -- 查看所有的数据库 show databases -- 创建数据库 create database [if not exists] test [charsetutf8] -- 切换 选择 …

thinkphp学习08-数据库的链式查询

前面课程中我们通过指向符号“->”多次连续调用方法称为&#xff1a;链式查询&#xff0c;当 Db::name(‘user’)时&#xff0c;返回查询对象(Query)&#xff0c;即可连缀数据库对应的方法&#xff0c;而每次执行一个数据库查询方法时&#xff0c;比如 where()&#xff0c;还…

九、IndexedDB前端缓存

前言 在通才 3D 数字工厂项目中,由于场景文件(glb 资源文件)过大,并且每次加载页面时,glb 文件都会被重新加载,造成页面加载缓慢,最后通过保存生成 Blob 格式存储到 IndexedDB 中,增加文件缓存,减少资源重复加载。 为什么需要 IndexedDB 随着前端技术的发展和浏览器…

selenium不自动关闭chrome,selenium hello world

selenium不自动关闭chrome 用visual studio的话&#xff0c;右键&#xff0c;在终端运行。 from selenium import webdriveroptions webdriver.ChromeOptions() options.add_experimental_option("detach", True) driver webdriver.Chrome(optionsoptions) url …

分裂联邦学习论文-混合联邦分裂学习GAN驱动的预测性多目标优化

论文标题&#xff1a;《Predictive GAN-Powered Multi-Objective Optimization for Hybrid Federated Split Learning》 期刊&#xff1a;IEEE Transactions on Communications, 2023 一、论文介绍 背景&#xff1a;联邦学习作为一种多设备协同训练的边缘智能算法&#xff0…

扩散模型的机器学习应用

https://medium.com/jmkernes 来源&#xff1a;从 StableDiffusion 生成……。 一、说明 这篇文章旨在帮助您推导和理解扩散模型。如果您读完本文后的第一个想法是&#xff1a;“为什么我没有想到这个&#xff1f;&#xff01;&#xff1f;” 那么酷&#xff0c;我成功了。我们…

Google推出Telecom Jetpack库,让Android通话应用创建更简单

Google推出Telecom Jetpack库&#xff0c;让Android通话应用创建更简单 Telecom Jetpack库的最新Alpha版本已经推出。该库提供了多个API&#xff0c;以简化Android开发者创建语音和/或视频通话应用程序的过程&#xff0c;支持常见功能&#xff0c;例如接听/拒绝、音频路由等等…

Packet Tracer - Configuring Extended ACLs - Scenario 1

Packet Tracer - 配置扩展访问控制列表 - 场景1 地址表 目标 第一部分&#xff1a;配置、应用并验证一个编号扩展访问控制列表&#xff08;Extended ACL&#xff09; 第二部分&#xff1a;配置、应用并验证一个命名扩展访问控制列表&#xff08;Extended Named ACL&#xff…

Python电能质量扰动信号分类(五)基于CNN-Transformer的一维信号分类模型

目录 往期精彩内容&#xff1a; 引言 1 数据集制作与加载 1.1 导入数据 1.2 制作数据集 2 CNN-Transformer分类模型和超参数选取 2.1定义CNN-Transformer分类模型 2.2 设置参数&#xff0c;训练模型 3 模型评估 3.1 准确率、精确率、召回率、F1 Score 3.2 十分类混淆…

IDEA—初始化配置

注&#xff1a;以下红框圈的部分&#xff0c;均为已设置好的 外观与行为 编辑器 高级设置 按两次 shift 弹出提示问题解决

数据仓库 Apache Hive

一、数据分析 1、数据仓库 数据仓库&#xff08;英语&#xff1a;Data Warehouse&#xff0c;简称数仓、DW&#xff09;&#xff0c;是一个用于存储、分析、报告的数据系统。 数据仓库的目的是构建面向分析的集成化数据环境&#xff0c;分析结果为企业提供决策支持&#xff08…

如何在Spring Boot中使用EhCache缓存

1、EhCache介绍 在查询数据的时候&#xff0c;数据大多来自于数据库&#xff0c;我们会基于SQL语句与数据库交互&#xff0c;数据库一般会基于本地磁盘IO将数据读取到内存&#xff0c;返回给Java服务端&#xff0c;我们再将数据响应给前端&#xff0c;做数据展示。 但是MySQL…

重磅!OpenAI正式发布,自定义ChatGPT商店!

1月11日凌晨&#xff0c;OpenAI在官网正式发布了&#xff0c;自定义GPT商店&#xff0c;可以帮助用户找到目前最好用、流行的自定义ChatGPT助手。 在2024年第一季度&#xff0c;OpenAI将启动GPT 开发者收入计划。首先&#xff0c;美国地区的开发者将根据用户对其 GPT 的使用情…