算法10(力扣20)-有效的括号

1、问题

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

  有效字符串需满足:

            左括号必须用相同类型的右括号闭合。

            左括号必须以正确的顺序闭合。

            每个右括号都有一个对应的相同类型的左括号。

2、示例

(1)

         输入:s = "()"

        输出:true

(2)

        输入:s = "()[]{}"

        输出:true

(3)

        输入:s = "(]"

        输出:false

3、思路

        先判断是否括号数是不是偶数,然后通过循环遍历字符串中的每一项,通过switch匹对符号,是左括号都压入栈,是右括号通过匹配判断弹出的是否和遍历到的右括号匹配,不匹配返回false

4、步骤

(1)判断括号数

        

(2)设置空栈(空数组)

(3)循环遍历字符串中的各项

        1)循环内通过switch-case匹配判断,左括号都压入栈,是右括号通过匹配判断弹出的是否和遍历到的右括号匹配,不匹配返回false

        

(4)返回栈长,若为空说明匹配完闭

        

5、完整代码(这里有两个方法isValid是官方的方法,法二是这里讲述的方法)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>有效的括号</title>
</head>
<body><p>给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。<p>有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括号。</p></p><p>输入:s = "()"输出:true</p><p>输入:s = "()[]{}"输出:true</p><p>输入:s = "(]"输出:false</p><p>(不行)将字符串切割成数组,然后将数组的半数长度存入变量作为终止条件,然后外层循环从前往后变量,内层循环从后向前遍历以空间遇到和上一个不同的存入不同的数组,需要三个数组</p>
</body>
<script>// let str = "()"let str ='(]'isValid(str)isValid1(str)function isValid(s) {const n = s.length;// 括号数是奇数,不符合,直接返回falseif (n % 2 === 1) {return false;}// 创建右括号到左括号的映射,方便找到左括号const pairs = new Map([[')', '('],[']', '['],['}', '{']]);// console.log(pairs);// 建立空栈,方便存储和弹出const stk = [];// 遍历字符串的每一项for (let ch of s) {// console.log(ch);// 如果字符中有map中的一个右括号(可以是)或]或}),查看是否有相应的左括号进行匹配if (pairs.has(ch)) {// 如果栈为空或者栈中无左括号可以与之匹配,返回falseif (!stk.length || stk[stk.length - 1] !== pairs.get(ch)) {return false;}// 可以匹配弹出左括号stk.pop();}else {// 左括号压入栈stk.push(ch);}};// 遍历完后空栈为true,否则false// console.log(!stk.length,1111);return !stk.length;}function isValid1(s){let n = s.length// 括号数是奇数,不符合,直接返回falseif (n % 2 === 1) {return false;}// 先用循环,然后在循环中使用switch、case判断括号是否符合,左括号压入栈、右括号弹出// 空栈存储let stk = []for (let i of s) {// console.log(i); switch (i) {case '(':case '[':case '{':stk.push(i)break;  case ')':// stk.pop返回值是弹出的那一项(pop从数组最后开始弹出)// console.log(stk.pop());if (stk.pop()!=='(') return falsebreak;case ']':if (stk.pop()!=='[') return falsebreak;case '}':if (stk.pop()!=='{') return falsebreak;                                     }}// console.log(!stk.length);// 遍历完后空栈为true,否则false// console.log(!stk.length,1111);return !stk.length}
</script>
</html>

6、力扣通过代码

var isValid = function(s) {let n = s.length// 括号数是奇数,不符合,直接返回falseif (n % 2 === 1) {return false;}// 先用循环,然后在循环中使用switch、case判断括号是否符合,左括号压入栈、右括号弹出// 空栈存储let stk = []for (let i of s) {// console.log(i); switch (i) {case '(':case '[':case '{':stk.push(i)break;  case ')':// stk.pop返回值是弹出的那一项(pop从数组最后开始弹出)// console.log(stk.pop());if (stk.pop()!=='(') return falsebreak;case ']':if (stk.pop()!=='[') return falsebreak;case '}':if (stk.pop()!=='{') return falsebreak;                                     }}// console.log(!stk.length);// 遍历完后空栈为true,否则false// console.log(!stk.length,1111);return !stk.length 
};

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

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

相关文章

每日一题——二叉树的前序遍历和中序遍历和后序遍历

文章目录 二叉树的前序、中序与后序遍历题目描述数据范围&#xff1a;示例&#xff1a;示例 1&#xff1a; 解题思路1. 递归法2. 迭代法 代码实现&#xff08;递归法&#xff09;代码解析示例输出复杂度分析 中序遍历后序遍历 二叉树的前序、中序与后序遍历 题目描述 给定一棵…

【优选算法】8----四数之和

有看过我上篇算法博客并且去做过的铁子们&#xff0c;对这道题的话应该就不会那么陌生了&#xff0c;因为这两道题 的解题思路有着异曲同工之妙~ -----------------------------------------begin------------------------------------- 题目解析&#xff1a; 跟三数之和就多了…

【开源免费】基于SpringBoot+Vue.JS校园失物招领系统(JAVA毕业设计)

本文项目编号 T 150 &#xff0c;文末自助获取源码 \color{red}{T150&#xff0c;文末自助获取源码} T150&#xff0c;文末自助获取源码 目录 一、系统介绍二、数据库设计三、配套教程3.1 启动教程3.2 讲解视频3.3 二次开发教程 四、功能截图五、文案资料5.1 选题背景5.2 国内…

NextJs - ServerAction获取文件并处理Excel

NextJs - ServerAction获取文件并处理Excel 一. 客户端二. ServerAction 处理 一. 客户端 use client; import { uploadExcel } from actions/batchInquirySystem/api; import type { UploadProps } from antd; import { Upload } from antd;/*** 创建问询内容*/ const Page …

C++/CLI(Common Language Runtime)关键点详解

C++/CLI(Common Language Runtime)是 Microsoft Visual C++ 的一个扩展,允许使用 .NET Framework 的功能,同时保留对本机 C++ 代码的访问。当您需要在 C++ 和 C# 之间进行互操作时,C++/CLI 是一种常见的选择,因为它可以作为桥梁,将托管代码(如 C#)与非托管代码(如 C+…

python 找出合并并排序两个有序列表后的第n个最小元素

编写一个程序&#xff0c;找出合并并排序两个有序列表后的第n个最小元素。 定义函数find_smallest_number()&#xff0c;该函数接受三个参数&#xff1a;两个列表和一个整数n。假设输入的列表始按升序排序。在函数内部&#xff0c;按升序合并两个列表。然后&#xff0c;从列表…

android wifi 热点名称的默认配置

在android11里 frameworks/opt/net/wifi/service/res/values/config.xml 281 <string name"wifi_tether_configure_ssid_default" translatable"false">AndroidAP</string> 282 <!-- Do not translate. Default access point SSID…

2025美赛倒计时,数学建模五类模型40+常用算法及算法手册汇总

数学建模美赛倒计时&#xff0c;对于第一次参加竞赛且没有相关基础知识的同学来讲&#xff0c;掌握数学建模常用经典的模型算法知识&#xff0c;并熟练使用相关软件进行建模是关键。本文将介绍一些常用的模型算法&#xff0c;以及软件操作教程。 数学建模常用模型包括&#xf…

【深度学习】常见模型-循环神经网络(Recurrent Neural Network, RNN)

循环神经网络&#xff08;RNN&#xff09; 概念简介 循环神经网络&#xff08;Recurrent Neural Network, RNN&#xff09;是一种用于处理序列数据&#xff08;如时间序列、文本序列等&#xff09;的神经网络模型。与传统神经网络不同&#xff0c;RNN 的结构具有记忆能力&…

Matlab总提示内存不够用,明明小于电脑内存

目录 前言情况1&#xff08;改matlab最大内存限制&#xff09;情况2&#xff08;重启电脑&#xff09;情况3 前言 在使用matlab中&#xff0c;有时候需要占用的内存并没有超过电脑内存依旧会报错&#xff0c;提示内存不够用&#xff0c;可以尝试下面几种方法&#xff0c;总有一…

数据结构(Java)——二叉树

1.概念 二叉树是一种树形数据结构&#xff0c;其中每个节点最多有两个子节点&#xff0c;通常被称为左子节点和右子节点。二叉树可以是空的&#xff08;即没有节点&#xff09;&#xff0c;或者由一个根节点以及零个或多个左子树和右子树组成&#xff0c;其中左子树和右子树也分…

PyTest自学 - pytest夹具使用初步

<< 返回目录 1 PyTest自学 - pytest夹具使用初步 夹具可以为测试用例提供资源(测试数据)、执行预置条件、执行后置条件&#xff0c;夹具可以是函数、类或模块&#xff0c;使用pytest.fixture装饰器进行标记。 1.1 夹具的作用范围 夹具的作用范围&#xff1a; 函数范围…

Windows电脑上记录工作待办清单的工具用哪个?

在Windows电脑上记录日常工作待办清单的工具用哪一个比较好呢&#xff1f;想要工作效率高&#xff0c;借助Windows电脑上的待办清单工具&#xff0c;可以帮助大家快速完成各项任务&#xff0c;今天给大家盘点几款工作待办清单工具。 Windows自带的便笺Stickynotes Windows自…

H266/VVC 量化编码中 JCCR 技术

色度联合编码 JCCR VVC 支持色度分量联合编码(Joint Coding of Chroma Residual&#xff0c;JCCR)&#xff0c; 两个色度残差联合编码。通过 TU 的标志位 tu_joint_cbcr_residual_flag 指定该工 具&#xff0c;并通过 CBF 来隐式传输所选的模式。仅当 TU 的至少一个色度分量的 …

ZooKeeper 数据模型

ZooKeeper 数据模型 ZooKeeper 拥有层次化的命名空间&#xff0c;类似分布式文件系统&#xff0c;但每个节点不仅能有子节点&#xff0c;还可关联数据。节点路径为规范的绝对路径&#xff0c;用斜杠分隔&#xff0c;无相对引用。路径命名有如下约束&#xff1a; 路径名不能包…

云原生时代,如何构建高效分布式监控系统

文章目录 一.监控现状二.Thanos原理分析SidecarQuerierStoreCompactor 三.Sidecar or ReceiverThanos Receiver工作原理 四.分布式运维架构 一.监控现状 Prometheus是CNCF基金会管理的一个开源监控项目&#xff0c;由于其良好的架构设计和完善的生态&#xff0c;迅速成为了监控…

关于扫雷的自动补空实现C语言

关于扫雷的自动补空实现C语言 相信很多朋友在用C语言实现扫雷功能时&#xff0c;都想实现扫雷里面的的自动补足功能&#xff0c;但总是难以实现&#xff0c;在这里我将分享一种方法——递归思想 先看代码&#xff01; 位置在game.c //判断附近雷区并过滤空白区&#xff08;…

图形化数据报文转换映射工具

目录 概要整体架构流程技术名词解释技术细节小结 概要 在当今数字化时代&#xff0c;数据的处理和分析是企业、科研机构以及各类组织日常运营的核心环节。数据来源广泛&#xff0c;格式多样&#xff0c;常见的数据格式包括XML&#xff08;可扩展标记语言&#xff09;和JSON&a…

LINUX下设置分离状态(Detached State)和未设置分离状态的主要区别在于线程资源的管理方式和线程的生命周期。以下是两种状态的对比:

1. 设置分离状态&#xff08;Detached State&#xff09; 资源管理&#xff1a; 线程终止时&#xff0c;系统会自动释放与线程相关的所有资源&#xff08;如线程栈、线程控制块&#xff09;。不需要其他线程显式回收&#xff08;pthread_join&#xff09;。 线程生命周期&…

微前端qiankun的基本使用(vue-element-admin作为项目模版)

微前端qiankun的基本使用(vue-element-admin作为项目模版) qiankun架构特点主应用netmoni_master改造工程项目目录结构子项目配置:子应用注册配置项container:子应用挂载节点配置项activeRule:子应用路由子应用netmoni_child1改造目录结构项目配置:src/settings中配置子应…