ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

LeetCode 有效括号

2022-02-25 21:32:31  阅读:216  来源: 互联网

标签:字符 ch return 有效 stack 括号 false LeetCode


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

有效字符串需满足:左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。

解决方法:有效括号可采用栈的原理。遍历字符串,对于左括号入栈,遇到右括号,则将栈顶匀速弹出,如果两括号刚好匹配,则为有效字符。


代码实现:

class Solution {
    public boolean isValid(String s) {
        if(s.length()==0){
            return true;
        }
        Stack <Character> stack = new Stack(); //创建一个字符型的栈。
        for(char ch : s.toCharArray()) { //字符数组的遍历方式
            //左括号就入栈
            if(ch=='('||ch=='['||ch=='{'){
                stack.push(ch);
            } else { //不是左括号,那就要看第一个出栈的括号与之是否匹配,不匹配返回false。
                if(stack.isEmpty()){ //出现右括号,即将要出栈的时候,发现栈为空,没有元素可出。则返回false
                    return false; 
                } else{
                      char temp = stack.pop();
                      if(ch==')' && temp != '('){
                          return false;
                      }else if(ch==']' && temp != '[') {
                          return false;
                      }else if(ch=='}' && temp != '{'){
                          return false;
                      }
                }
            }
        }
       //循环结束,如果栈为空,说明刚好匹配;如果栈不为空,说明找完所有的右括号,入栈的左括号没有匹配完,则返回false。 
        return stack.isEmpty() ? true : false; 
    }
}

ps:

ToCharArray( ):将字符串对象中的字符转换为一个字符数组。

for(char ch: a ) :字符遍历循环

标签:字符,ch,return,有效,stack,括号,false,LeetCode
来源: https://blog.csdn.net/m0_51058777/article/details/123140560

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有