【算法系列-栈与队列】匹配消除系列

【算法系列-栈与队列】栈解决匹配消除问题

文章目录

  • 【算法系列-栈与队列】栈解决匹配消除问题
    • 1. 算法分析🛸
    • 2. 有效的括号(LeetCode 20)
      • 2.1 思路分析🎯
      • 2.2 代码示例🌰
    • 3. 删除字符串中的相邻重复项(LeetCode 1047)
      • 3.1 思路分析🎯
      • 3.2 代码示例🌰
    • 4. 逆波兰表达式(LeetCode 150)
      • 4.1 思路分析🎯
      • 4.2 代码示例🌰

1. 算法分析🛸

栈能够应用于许多匹配消除的场景,如括号匹配、删除相邻重复项等,就像在玩游戏中的消除对对碰一样,在这些场景下合理运用栈来匹配消除的对象是比较高效的!接下来就来几道题试一试:

2. 有效的括号(LeetCode 20)

【题目链接】20. 有效的括号 - 力扣(LeetCode)

2.1 思路分析🎯

这是一道很经典的题目,可以通过栈来解决这道题,同时可以有两种思路:

  • 左括号入栈
  • 右括号入栈

左括号入栈便是在匹配到左括号时将该元素加入栈,匹配到右括号时则将判断栈顶元素是否能与当前右括号组合成一个完整的括号,思路比较好理解

2.2 代码示例🌰

class Solution {public boolean isValid(String s) {Stack<Character> stack = new Stack<>();for (int i = 0;i < s.length();i++) {char c = s.charAt(i);if (c == '(' || c == '{' || c == '[') {stack.push(c);}else {if (stack.isEmpty()) {return false;}char pc = stack.peek();String str = "" + pc + c;if (str.equals("()") || str.equals("{}") || str.equals("[]")) {stack.pop();}else {return false;}}}return stack.isEmpty();}
}

与左括号入栈不同,这里使用右括号入栈

当匹配到左括号时,将该左括号对应的右括号入栈;

当匹配到右括号时:

  • 判断当前栈是否为空,为空则返回false;

  • 若不为空,判断是否与栈顶元素相同:

    • 不同则表示前面没有出现与当前右括号匹配的左括号(注:因为我们前面是选择将右括号入栈,所以匹配的是右括号)
    • 相同则表示前面出现过与之匹配的左括号,将其弹出栈

直到循环结束,判断当前栈是否为空,空则返回true,反之返回false

代码如下:

class Solution {public boolean isValid(String s) {Stack<Character> stack = new Stack<>();for (int i = 0;i < s.length();i++) {char c = s.charAt(i);if (c == '(') {stack.push(')');}else if (c == '{') {stack.push('}');}else if (c == '[') {stack.push(']');}else if (stack.isEmpty() || stack.peek() != c) {return false;}else {stack.pop();}}return stack.isEmpty();}
}

3. 删除字符串中的相邻重复项(LeetCode 1047)

【题目链接】1047. 删除字符串中的所有相邻重复项 - 力扣(LeetCode)

3.1 思路分析🎯

与括号匹配思路一致,只是将对括号进行匹配换成了对字符进行匹配

3.2 代码示例🌰

class Solution {public String removeDuplicates(String s) {Stack<Character> stack = new Stack<>();for (int i = 0;i < s.length();i++) {char c = s.charAt(i);if (stack.isEmpty()) {stack.push(c);}else if (stack.peek() == c) {stack.pop();}else {stack.push(c);}}StringBuffer sub = new StringBuffer();while (!stack.isEmpty()) {sub.insert(0, stack.pop());}return sub.toString();}
}

4. 逆波兰表达式(LeetCode 150)

【题目链接】150. 逆波兰表达式求值 - 力扣(LeetCode)

4.1 思路分析🎯

理清楚逆波兰表达式的概念后,思路与上述两道题一致,都是匹配元素发生更换但过程一致

4.2 代码示例🌰

class Solution {public int evalRPN(String[] tokens) {Stack<Integer> stack = new Stack<>();for (String s : tokens) {int x = 0, y = 0;if (s.equals("+")) {x = stack.pop();y = stack.pop();stack.push(y + x);}else if (s.equals("-")) {x = stack.pop();y = stack.pop();stack.push(y - x);}else if (s.equals("*")) {x = stack.pop();y = stack.pop();stack.push(y * x);}else if (s.equals("/")) {x = stack.pop();y = stack.pop();stack.push(y / x);}else {stack.push(Integer.valueOf(s));}}return stack.peek();}
}

以上便是对栈解决匹配消除问题的介绍了!!后续还会继续分享其它算法系列内容,如果这些内容对大家有帮助的话请给一个三连关注吧💕( •̀ ω •́ )✧( •̀ ω •́ )✧✨

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

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

相关文章

Web Service

目录 1、概览2、SOA架构2.1 Web Service的基础协议2.2 Web Service协议栈 3 Web Service的分类3.1 应用领域3.2 服务器类型 4 厂商支持4.1 Java EE4.2 .NET4.3 WebSphere 5 其他5.1 微服务与 Web Service5.1.1 微服务与 Web 服务之间的区别5.1.2 微服务、 Web 服务的最佳实践 5…

laravel 查询数据库

数据库准备 插入 三行 不同的数据 自行搭建 laravel 工程 参考 工程创建点击此处 laravel 配置 数据库信息 DB_CONNECTIONmysql #连接什么数据库 DB_HOST127.0.0.1 # 连接 哪个电脑的 ip &#xff08;决定 电脑 本机&#xff09; DB_PORT3306 # 端口 DB_DATABASEyanyu…

FloodFill 算法(DFS)

文章目录 FloodFill 算法&#xff08;DFS&#xff09;图像渲染岛屿数量岛屿的最大面积被围绕的区域太平洋大西洋水流问题扫雷游戏衣橱整理 FloodFill 算法&#xff08;DFS&#xff09; 漫水填充(Flood Fi)算法是一种图像处理算法&#xff0c;在计算机图形学和计算机视觉中被广泛…

超详细的 Stable Diffusion Webui入门教程(二)基础操作

前言 工欲善其事&#xff0c;必先利其器&#xff01;今天我们聊聊 Stable Diffusion WebUI 的基础操作以及各个参数都代表了什么。 所有的AI设计工具&#xff0c;安装包、模型和插件&#xff0c;都已经整理好了&#xff0c;&#x1f447;获取~ 一、大模型的切换 在 Stable D…

【从零开始的LeetCode-算法】3185. 构成整天的下标对数目 II

给你一个整数数组 hours&#xff0c;表示以 小时 为单位的时间&#xff0c;返回一个整数&#xff0c;表示满足 i < j 且 hours[i] hours[j] 构成 整天 的下标对 i, j 的数目。 整天 定义为时间持续时间是 24 小时的 整数倍 。 例如&#xff0c;1 天是 24 小时&#xff0c…

[Vue3核心语法] ref、reactive响应式数据

定义: ref用来定义&#xff1a;基本类型数据、对象类型数据&#xff1b; reactive用来定义&#xff1a;对象类型数据。 使用原则: 若需要一个基本类型的响应式数据&#xff0c;必须使用ref。 若需要一个响应式对象&#xff0c;层级不深&#xff0c;ref、reactive都可以。 …

项目管理这些问题,你是不是忍了很久?

项目管理中常见的问题&#xff0c;你是不是早就感到无奈了&#xff1f;项目进度滞后、成本超支、团队协作不畅、任务分配模糊、资源分配不合理……这些问题常常让人感到力不从心。 无论是关键节点的拖延&#xff0c;还是多部门间的沟通障碍&#xff0c;最终都会拖慢项目进展&a…

京东大模型革命电商搜推技术:挑战、实践与未来趋势

大模型对搜推技术产生了深远的影响&#xff0c;极大地推动了搜推技术的演进趋势&#xff0c;使得搜推更加的智能化和个性化&#xff0c;然而在搜推中引入大模型时同样面临一系列的挑战&#xff0c;例如商品知识的幻觉&#xff0c;复杂查询的理解&#xff0c;个性化商品推荐&…

酒店预订订房小程序源码系统 多酒店入驻+打造类似美团的酒店模式 带完整的安装代码包以及搭建部署教程

系统概述 随着移动互联网的普及&#xff0c;小程序因其轻量级、无需下载安装、即用即走的特点&#xff0c;迅速成为各行业的标配。对于酒店预订行业而言&#xff0c;小程序不仅能够有效提升用户体验&#xff0c;还能降低运营成本&#xff0c;提高转化率。本源码系统正是基于这…

js实现数组中数据有则删除无则添加-[‘12123‘,‘432233‘...]

可以使用indexOf方法来判断数组中是否存在某个元素&#xff0c;如果存在则使用splice方法删除该元素&#xff0c;如果不存在则使用push方法添加该元素。 下面是具体的代码实现&#xff1a; function addOrRemove(arr, item) {const index arr.indexOf(item);if (index -1) {…

Dockerfile和docker-compose详解

Dockerfile和docker-compose详解 文章目录 Dockerfile和docker-compose详解一、Dockerfile1. Dockerfile简介2. 构建镜像3. Dockerfile命令&#xff08;1&#xff09;FROM&#xff08;2&#xff09;WORKDIR&#xff08;3&#xff09;RUN&#xff08;4&#xff09;COPY&#xff…

MATLAB智能算法 - Immunity Algorithm免疫算法

Immunity Algorithm免疫算法 智能算法是路线规划、深度学习等等一系列领域所使用的优化算法&#xff0c;是算法进阶之路的必备之路。 前言&#xff1a;本文主要围绕解决TSP旅行商问题展开&#xff0c;对于机器人的路线规划以及非线性方程求解的问题等解决方案 对于一些其他智能…

Rust的泛型基础与实践

什么是泛型&#xff1f; 想象一下&#xff0c;我们想定义一个函数&#xff0c;它可以用来计算任意类型数据的最大值。如果我们只考虑整数&#xff0c;我们可以这样写&#xff1a; fn max(a: i32, b: i32) -> i32 {if a > b {a} else {b} }但是&#xff0c;如果我们还想…

【每日刷题】Day142

【每日刷题】Day142 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 1. 1219. 黄金矿工 - 力扣&#xff08;LeetCode&#xff09; 2. 980. 不同路径 III - 力扣&#xff0…

C++20中头文件ranges的使用

<ranges>是C20中新增加的头文件&#xff0c;提供了一组与范围(ranges)相关的功能&#xff0c;此头文件是ranges库的一部分。包括&#xff1a; 1.concepts: (1).std::ranges::range:指定类型为range&#xff0c;即它提供开始迭代器和结束标记(it provides a begin iterato…

MP9928模块分析

MP9928 是一款高性能的同步降压 DC/DC 转换器控制器 IC&#xff0c;具有宽输入范围。以下是其操作和关键特性的总结&#xff1a; 概述 电流模式控制&#xff1a;MP9928 使用电流模式、可编程开关频率控制架构&#xff0c;通过外部 N 沟道 MOSFET 开关来调节输出电压。 反馈和…

PRCV2024:可信AI向善发展与智能文档加速构建

目录 0 写在前面1 GAI时代的挑战&#xff1a;图像内容安全1.1 图像篡改与对抗攻击1.2 生成式图像鉴别1.3 人脸鉴伪模型体验1.4 助力可信AI向善发展 2 GAI时代的机遇&#xff1a;大模型加速器2.1 TextIn大模型加速器2.2 通用文档解析2.3 文本向量模型 3 总结 0 写在前面 中国模…

认识一下:__asm { int 80h; LINUX - sys_fork }

这行代码 __asm { int 80h; LINUX - sys_fork } 使用了汇编语言的语法来直接调用 Linux 系统调用 fork。下面是对这行代码的详细解析&#xff1a; 代码解析 __asm: 这是一个用于嵌入汇编代码的指令&#xff0c;通常在 C 或 C 代码中使用&#xff0c;允许开发者直接插入汇编语言…

信息安全系统设计第七周

文章目录 密码系统设计学习内容AI 对学习内容的总结&#xff08;1分&#xff09;要求总结 第10章&#xff1a;身份认证和PKI理论基础第11章&#xff1a;实战PKI对 AI 总结的反思与补充&#xff08;2分&#xff09;要求反思与补充 学习思维导图&#xff08;2分&#xff09;要求思…

Pytorch 实现图片分类

CNN 网络适用于图片识别&#xff0c;卷积神经网络主要用于图片的处理识别。卷积神经网络&#xff0c;包括一下几部分&#xff0c;输入层、卷积层、池化层、全链接层和输出层。 使用 CIFAR-10 进行训练&#xff0c; CIFAR-10 中图片尺寸为 32 * 32。卷积层通过卷积核移动进行计…