LeetCode20.有效的括号——java

题目描述:

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

有效字符串需满足:

左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。

示例 1:

输入:s = “()” 输出:true 示例 2:

输入:s = “()[]{}” 输出:true 示例 3:

输入:s = “(]” 输出:false 示例 4:

输入:s = “([)]” 输出:false 示例 5:

输入:s = “{[]}” 输出:true

代码描述:

class Solution {
    public boolean isValid(String s) {
            Stack<Character> stack=new Stack<>();
          
          for(int i=0;i<s.length();i++)
          {
              char ch=s.charAt(i);
              if(ch=='(')
              {
                  stack.push(')');
              }else if(ch=='{')
              {
                  stack.push('}');
              }else if(ch=='[')
              {
                  stack.push(']');
              }else if(stack.isEmpty()||stack.peek()!=ch)
              {
                  return false;
              }else
              {
                  stack.pop();
              }
          }
          return stack.isEmpty();
            
    }
}

版权声明:本文为m0_51799816原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。