一、题目描述
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 注意空字符串可被认为是有效字符串。
示例 1:
输入: "()" 输出: true 示例 2:
输入: "()[]{}" 输出: true 示例 3:
输入: "(]" 输出: false 示例 4:
输入: "([)]" 输出: false 示例 5:
输入: "{[]}" 输出: true
二、思路
1、借助于两个栈,字符串的字符依次入栈stack1,stack2为空。
2、将栈stack1中的字符char依次弹出,假如char和stack2的栈顶元素是匹配的括号,则将stack2的栈顶元素弹出,否则将该字符char入栈stack2,循环执行该步骤,直至stack1为空。
3、假如stack2为空,则为有效字符串,返回true,否则返回false。
三、代码
import java.util.Stack;
public class Solution {
public boolean isValid(String s) {
int len=s.length();
Stack<Cha