iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >怎么判断括号是否有效
  • 363
分享到

怎么判断括号是否有效

2024-04-02 19:04:59 363人浏览 独家记忆
摘要

本篇内容主要讲解“怎么判断括号是否有效”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么判断括号是否有效”吧!题目给定一个只包括 '(', &#

本篇内容主要讲解“怎么判断括号是否有效”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么判断括号是否有效”吧!

题目

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

有效字符串需满足:

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

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

  • 注意空字符串可被认为是有效字符串。

示例 1:

输入: "()"  输出: true

示例 2:

输入: "()[]{}"  输出: true

示例 3:

输入: "(]" 输出: false

示例 4:

输入: "([)]" 输出: false

示例 5:

输入: "{[]}" 输出: true LeetCode 地址:https://leetcode-cn.com/problems/valid-parentheses

解题思路

这道题考察的是就是验证括号的对称性,比如“([{}])”这种字符串就是正确的,应该返回 true,而“([{})]”这种字符串就是错误的,应该返回  false。

从上面的题目可以看出,括号总共分为三类:小括号、中括号和大括号,那么我们可以利用栈先进后出的特性,将所有左边的括号(“(”、“[”、“{”)先入栈,然后再碰到右括号时,让它与栈顶的元素进行匹配,比如当遇到“)”时,如果栈顶是“(”,则说明匹配成功,栈顶元素出栈再继续字符串循环的流程,如果匹配错误就直接返回  false。

假设我们要匹配字符串“(([]))”是否合法?那么执行流程就是这样的。

首先遇到左边括号,先入栈:

怎么判断括号是否有效

接下来又是左边括号,继续入栈:

怎么判断括号是否有效

然后又是左边括号,继续入栈:

怎么判断括号是否有效

接下来是右边括号,与栈顶元素匹配,“[]”为一对合法的括号,匹配成功栈顶元素出栈:

怎么判断括号是否有效

接下来又是右边括号,与栈顶元素匹配,“()”为一对合法的括号,匹配成功栈顶元素出栈:

怎么判断括号是否有效

接下来又是右边括号,与栈顶元素匹配,“()”为一对合法的括号,匹配成功栈顶元素出栈:

怎么判断括号是否有效

当字符串循环结束并且栈为空栈时,则证明此字符串的括号匹配合法,最终的效果如下图所示:

怎么判断括号是否有效

那么接下来我们就用代码来实现一下整个过程...

实现代码一

public boolean isValid(String s) {     int slen = s.length(); // 括号的长度     if (slen % 2 == 1) { // 括号不是成对出现直接返回 false         return false;     }     // 把所有对比的括号存入 map,对比时用     Map<Character, Character> map = new HashMap<>();     map.put(')', '(');     map.put('}', '{');     map.put(']', '[');     // 定义栈,用于存取括号(辅助比较)     Stack<Character> stack = new Stack<>();     for (int i = 0; i < slen; i++) { // 循环所有字符         char c = s.charAt(i);         if (map.containsKey(c)) { // 为右边的括号,如 ')'、'}' 等             if (stack.isEmpty() || stack.peek() != map.get(c)) { // 栈为空或括号不匹配                 return false;             }             stack.pop(); // 是一对括号,执行出栈(消除左右括号)         } else { // 左边括号,直接入栈             stack.push(c);         }     }     return stack.isEmpty(); }

我们在 LeetCode 中提交一下代码,执行结果如下:

怎么判断括号是否有效

代码解析

以上代码的 map  集合是用于定义括号的匹配规则,比如“)”对应的匹配值是“(”,“]”的匹配值是“[”等,然后我们再去循环待验证的字符串,遇到左括号直接入栈,遇到右括号让它与栈顶元素匹配,等到整个字符串循环结束,如果栈为空则说明字符串的括号合法。

复杂度分析

时间复杂度:O(n),遍历了一遍整个字符串。空间复杂度:O(n)。

实现代码二

除了使用栈之外,我们还可以使用借助 Java 中的 replace  方法来实现,我们可以循环的消除字符串中的括号,比如将“()”或“[]”或“{}”循环得替换为空,最后在执行完成之后如果字符串为空,则说明字符串中的括号是合法的,具体实现代码如下:

public boolean isValid(String s) {         int len;         do {             len = s.length();             // 消除成双成对的符号             s = s.replace("()", "").replace("[]", "").                     replace("{}", "");         } while (len != s.length()); // 不能再进行替换了,replace 方法没有替换任何字符         return s.length() == 0;     }

我们在 LeetCode 中提交一下代码,执行结果如下:

怎么判断括号是否有效

从运行结果来看,二者的执行效率相差还是很明显的:

怎么判断括号是否有效

到此,相信大家对“怎么判断括号是否有效”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 怎么判断括号是否有效

本文链接: https://www.lsjlt.com/news/84487.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么判断括号是否有效
    本篇内容主要讲解“怎么判断括号是否有效”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么判断括号是否有效”吧!题目给定一个只包括 '(', &#...
    99+
    2022-10-19
  • python实现有效的括号判断实例代码
    目录题目描述测试用例代码实现总结题目描述 给定一个只包括 '(',')','{','}','[',&#...
    99+
    2022-11-13
  • HTML怎么判断登陆是否失效
    这篇“HTML怎么判断登陆是否失效”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“HTML怎...
    99+
    2022-10-19
  • javascript怎么判断字符是否为符号
    这篇文章主要讲解了“javascript怎么判断字符是否为符号”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript怎么判断字符是否为符号”吧!使用正则表达式在Javascrip...
    99+
    2023-07-06
  • uniapp怎么判断是否有缓存
    在移动应用开发过程中,性能问题一直是开发者关注的重点之一。考虑到用户体验,我们通常会使用缓存来对移动应用进行优化。对于使用uniapp框架开发的应用,我们如何判断缓存是否存在呢?首先,让我们了解一下uniapp的缓存机制。uniapp使用的...
    99+
    2023-05-14
  • jquery怎么判断是否有数字
    这篇文章主要介绍了jquery怎么判断是否有数字的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jquery怎么判断是否有数字文章都会有所收获,下面我们一起来看看吧。   在j...
    99+
    2022-10-19
  • PHP怎么判断是否为有效的完全平方数
    这篇文章主要介绍“PHP怎么判断是否为有效的完全平方数”,在日常操作中,相信很多人在PHP怎么判断是否为有效的完全平方数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP怎么判断是否为有效的完全平方数”的疑...
    99+
    2023-06-20
  • java怎么判断数组是否有序
    可以通过遍历数组的方式来判断数组是否有序。具体步骤如下:1. 定义一个布尔变量isSorted,初始化为true。2. 使用for循...
    99+
    2023-08-15
    java
  • jquery怎么判断是否有某个class
    jquery怎么判断是否有某个class,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在jquery中,可以使用hasClass()方法来...
    99+
    2022-10-19
  • php怎么判断数组是否有序
    在 PHP 中,判断一个数组是否有序有多种方法。本文将介绍其中的两种方法。方法一:使用 array_multisort 函数array_multisort 是一个 PHP 函数,它可以同时对多个数组进行排序。它的用法是:bool array...
    99+
    2023-05-19
  • sql怎么判断表是否有数据
    可以使用以下方法来判断表是否有数据:1. 使用SELECT COUNT(*)语句统计表中的记录数,如果记录数大于0,则表示表...
    99+
    2023-09-23
    sql
  • java怎么判断锁是否被持有
    在Java中,可以使用synchronized关键字来实现对对象的锁定。要判断锁是否被持有,可以使用以下方法: 使用Thread....
    99+
    2023-10-28
    java
  • jquery怎么判断元素是否有class
    本教程操作环境:Windows10系统、jquery3.6版本、Dell G3电脑。jquery怎么判断元素是否有class?jquery 判断 元素是否具有某个class两种方法如下:1、hasClass(‘classname’)2、is...
    99+
    2023-05-14
    jQuery class
  • 怎么判断网站是否有cdn服务
    判断网站是否有cdn服务的方法:快捷键win+r,输入命令cmd,打开命令提示符窗口。通过nslookup检查网站是否存在cdn服务。例如:nslookup www.baidu.com,检测百度是否使用了cdn。如果检测结果Addresse...
    99+
    2022-10-09
  • js怎么判断对象是否有属性
    这篇文章给大家分享的是有关js怎么判断对象是否有属性的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的体验。2.可以处理表单,...
    99+
    2023-06-14
  • javascript怎么判断是否数字
    这篇文章给大家分享的是有关javascript怎么判断是否数字的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。javascript判断是否数字的方法:1、使用【isNaN()】函数,是js自带的全局函数;2、使用正...
    99+
    2023-06-14
  • 怎么判断mysql是否开启
    这篇文章主要讲解了“怎么判断mysql是否开启”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么判断mysql是否开启”吧!1、使用sql语句直接修改全局变量,数据库服务无需重启,但重启后变...
    99+
    2023-06-20
  • 怎么判断win10是否中毒
    要判断Windows 10是否中毒,可以进行以下步骤:1. 更新和运行杀毒软件:确保您的杀毒软件是最新版本,并对整个系统进行全面扫描...
    99+
    2023-09-04
    win10
  • php怎么判断字符串是否有重复
    判断步骤:1、利用str_split()把字符串转为字符数组,语法“str_split(字符串)”;2、利用array_unique()去除字符数组中重复的值,语法“array_unique(字符数组)”,会返回一个去重数组;3、使用cou...
    99+
    2022-07-04
    php数组 php php字符串
  • php怎么判断两数组是否有交集
    判断步骤:1、利用array_intersect_assoc()函数比较两个数组的键名和键值,语法“array_intersect_assoc(数组1,数组2)”,会返回一个交集数组;2、利用“===”运算符判断交集数组是否为空,语法“交集...
    99+
    2022-07-15
    php php数组
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作