文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么判断括号是否有效

2024-04-02 19:55

关注

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

题目

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

有效字符串需满足:

示例 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 中提交一下代码,执行结果如下:

怎么判断括号是否有效

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

怎么判断括号是否有效

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯