您现在的位置是:亿华云 > 域名
算法图解:如何判断括号是否有效?
亿华云2025-10-09 03:20:01【域名】5人已围观
简介本文转载自微信公众号「Java中文社群」,作者磊哥 。转载本文请联系Java中文社群公众号。今天要讲的这道题是 bilibili 今年的笔试真题,也是一道关于栈的经典面试题。经过前面文章的学习,我想很
本文转载自微信公众号「Java中文社群」,算法作者磊哥 。图解转载本文请联系Java中文社群公众号。何判号否
今天要讲的断括这道题是 bilibili 今年的笔试真题,也是有效一道关于栈的经典面试题。
经过前面文章的算法学习,我想很多朋友已经看出来了,图解我接下来要写的何判号否是一个关于「算法图解」的系列文章,中间可能会穿插少量的断括其他类型的文章,但「算法和数据结构」会是有效我今年文章输出的重点内容。
我在写这个算法系列的算法时候会注意两个问题:
保证算法的解题思路大家都能看懂,因此我会以图片的图解形式进行思路讲解,这样更直观、何判号否更易于理解; 在介绍完一个知识点之后,断括会进行大量的有效练习,以巩固所学的内容,源码库比如当我讲完「栈」结构之后,我会围绕着「栈」做一系列的经典面试题练习。学习算法最关键的是掌握解题的思路,只要思路对了,编写代码只是时间的问题。
那么接下来,我们就进入今天的正式内容...
题目
给定一个只包括 (, ), { , }, [, ] 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 注意空字符串可被认为是有效字符串。示例 1:
输入: "()" 输出: true示例 2:
输入: "()[]{ }" 输出: true示例 3:
输入: "(]" 输出: false示例 4:
输入: "([)]" 输出: false示例 5:
输入: "{ []}" 输出: true LeetCode 地址:https://leetcode-cn.com/problems/valid-parentheses解题思路
这道题考察的是就是验证括号的对称性,香港云服务器比如“([{ }])”这种字符串就是正确的,应该返回 true,而“([{ })]”这种字符串就是错误的,应该返回 false。
从上面的题目可以看出,括号总共分为三类:小括号、中括号和大括号,那么我们可以利用栈先进后出的特性,将所有左边的括号(“(”、“[”、“{ ”)先入栈,然后再碰到右括号时,让它与栈顶的元素进行匹配,比如当遇到“)”时,如果栈顶是“(”,则说明匹配成功,栈顶元素出栈再继续字符串循环的流程,如果匹配错误就直接返回 false。
假设我们要匹配字符串“(([]))”是否合法?那么执行流程就是这样的。
首先遇到左边括号,云南idc服务商先入栈:
接下来又是左边括号,继续入栈:
然后又是左边括号,继续入栈:
接下来是右边括号,与栈顶元素匹配,“[]”为一对合法的括号,匹配成功栈顶元素出栈:
接下来又是右边括号,与栈顶元素匹配,“()”为一对合法的括号,匹配成功栈顶元素出栈:
接下来又是右边括号,与栈顶元素匹配,“()”为一对合法的括号,匹配成功栈顶元素出栈:
当字符串循环结束并且栈为空栈时,则证明此字符串的括号匹配合法,最终的效果如下图所示:
那么接下来我们就用代码来实现一下整个过程...
实现代码一
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 中提交一下代码,执行结果如下:
从运行结果来看,二者的执行效率相差还是很明显的:
总结
本文我们讲了一道 bilibili 的笔试真题,同时它也是栈的经典面试题,我们可以借助栈的特性(先进后出)将所有的左括号入栈,当遇到右括号时让它与栈顶元素进行匹配,当字符串循环结束栈为空时,则说明此字符串的括号是合法的。当然我们在实际面试中,也可以使用 Java 的 replace 方法作为一个保底的实现方案,因为replace 方法的实现相对更简单一些,只是性能不怎么好。
很赞哦!(85)
相关文章
- 换新域名(重新来过)
- 在此期间,他们每天仍在这里卖大米,在理财方面个人感情有待提高。因为现在是收米的最佳时机。
- 为了避免将来给我们的个人站长带来的麻烦,在选择域名后缀时,我们的站长最好省略不稳定的后缀域名,比如n,因为我们不知道策略什么时候会改变,更不用说我们将来是否还能控制这个域名了。因此,如果站长不是企业,或者有选择的话,如果不能选择域名的cn类,最好不要选择它。
- 其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
- 尽量不要在域名中出现特殊字符,这样的域名很容易导致访问者输入错误,同时给人留下不专业的印象,降低网站的可信度,并流失大量潜在客户。
- 要如何了解反向解析和域名解析?新手该怎么去操作?
- 第六:这个圈子里的域名确实是赚钱的一些大玩家,至于小米农,有多少赚钱?几乎没有,也就是说,轿子里只有一个人,而且大多数人都抬着轿子。
- .net 适用于从事Internet相关的网络服务的机构或公司
- 5、使用企业名称的英文名称作为域名也是国内许多企业选择域名的一种方式,特别适合一些与计算机、网络和通信相关的行业。
- 为什么起域名意义非凡?起域名有什么名堂?
热门文章
站长推荐
域名资源有限,好域名更是有限,但机会随时都有,这取决于我们能否抓住机会。一般观点认为,国内域名注册太深,建议优先考虑外国注册人。外国注册人相对诚实,但价格差别很大,从几美元到几十美元不等。域名投资者应抓住机遇,尽早注册国外域名。
2. 不要花大价钱买域名,新手鉴别能力不足,容易投资失误。
众所周知,com域名拥有最大的流通市场和流通历史。最好选择com域名,特别是在购买域名时处理域名。其次可以是cn域名、net域名、org域名等主流域名,现在比较流行的王域名和顶级域名,都是值得注册和投资的。
a、变更前的公司证件扫描件(代码证或者营业执照)及联系人身份证复印件、变更后的公司证件扫描件(代码证或者营业执照)及新的联系人身份证复印件;身份证复印件需本人签名,公司证件复印件需加盖公章。
公司和个人选域名方法一样吗?有什么不同?
如果你的潜在终端必须是这个米(域名),那么潜在终端并不多,也没有硬通货,那么你的域名应该在终端有兴趣购买时出售。否则,你可能得自己留着吃。
4、域名传输时,取决于域名原始用户的邮箱是否有效,以及他是否将密码发送到此邮箱。
换新域名(重新来过)