leetcode 有效的括号(java)

ps 数据结构书上的那题 思路就是用栈

class Solution {
    public boolean isValid(String s) {
        boolean flag = true;
        Stack stack = new Stack<>();
        Map map = new HashMap<>();
        map.put(')', '(');
        map.put('}', '{');
        map.put(']', '[');
        for (int i = 0; i < s.length(); i++) {
            if (s.charAt(i) == '(' || s.charAt(i) == '{' || s.charAt(i) == '[') {
                stack.add(s.charAt(i));
            } else {
                if (stack.empty()||map.get(s.charAt(i)) != stack.pop()) {
                    flag = false;
                    break;
                }
            }
        }
        if (!stack.empty()) {
            return false;
        }
        return flag;
    }
}

你可能感兴趣的:(leetcode 有效的括号(java))