前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode - 有效的括号

LeetCode - 有效的括号

作者头像
晓痴
发布2019-08-22 16:51:27
4290
发布2019-08-22 16:51:27
举报
文章被收录于专栏:曌的晓痴

LeetCode第20题,难度简单。因为有些是中文网做的,有些是之前英文网做的,所以有些题目虽然内容一样,但是题目序号是不一样的,我这里采用的是中文网的题目序号。

原题地址:https://leetcode-cn.com/problems/valid-parentheses/

题目描述

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

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 注意空字符串可被认为是有效字符串。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/valid-parentheses

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

这题从题意上来看很简单,只需要不停的判断字符串中的大中小三中类型的括号是否能够匹配。

所以在解题时,采用了栈这种数据结构。遍历字符串,如果是左括号,就入栈;否则就把顶上的括号出栈,然后和当前的字符匹配看是不是刚好相反的括号。

如果到最后栈里面没有任何元素,那么一定是有效的括号字符串。

中文官网题解:

https://leetcode-cn.com/problems/valid-parentheses/solution/

个人题解:

代码语言:javascript
复制
class Solution {
  
    public boolean isValid(String s) {
        Deque<Character> stack = new LinkedList<>();
        for (char c : s.toCharArray()) {
            if (c == '(' || c == '[' || c == '{') {
                stack.push(c);
            } else {
                if (stack.isEmpty()) {
                    return false;
                }
                char cs = stack.pop();
                if ((cs == '(' && c != ')')
                        || (cs == '[' && c != ']')
                        || (cs == '{' && c != '}')) {
                    return false;
                }
            }
        }
        return stack.isEmpty();
    }
}

结果:

从结果上面来看,还是可以接受的,只用时5ms,超过了大部分提交。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 曌的晓痴 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档