美文网首页
有效的括号

有效的括号

作者: Airjoden | 来源:发表于2022-02-03 20:33 被阅读0次

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

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

解题步骤

package math;

import java.util.*;

public class Solution {
    public boolean isValid(String s){
        int n = s.length();
        if (n % 2 == 1){
            return false;
        }//字符串为单数返回false
        Map<Character, Character> pairs = new HashMap<Character, Character>(){{
            put(')','(');
            put(']','[');
            put('}','{');
        }}; //创建哈希表左右括号对应
        Deque<Character> stack = new LinkedList<Character>();  //创建栈
        for (int i = 0; i < n; i++){
            char ch = s.charAt(i);  //s字符串随下标输出对应字符
            if (pairs.containsKey(ch)){  //根据哈希表判断ch是否为右括号  containsKey(ch)表示哈希表里key为ch是否存在
                if (stack.isEmpty() || stack.peek()!=pairs.get(ch)){  //栈为空 或 栈顶不为左括号pairs.get(ch)取key为ch的值
                    return false;
                }
                stack.pop();  //将栈顶弹出
            } else {
                stack.push(ch);  //将ch字符入栈
            }
        }
        return stack.isEmpty();
    }
}

相关文章

  • 回溯算法和深度优先搜索(二)

    先看一道题目: 括号生成。 输入一个整数 ,罗列出所有有效的括号组合。有效的括号组合是指 左括号开始,右括号结束,...

  • 括号生成 (有效括号)

    题目 数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。 示例: 输入...

  • 有效括号

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

  • 有效括号

    import java.util.*; /** 给定一个只包括 '(',')','{','}','[',']' 的...

  • 有效括号

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

  • 有效的括号

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

  • 有效的括号

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

  • 有效的括号

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

  • 有效的括号

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

  • 有效的括号

    题目描述 给定一个只包括‘(‘,’)’, ‘{‘,’}’, ‘[',']’的字符串,判断字符串是否有效有效字符串需...

网友评论

      本文标题:有效的括号

      本文链接:https://www.haomeiwen.com/subject/hzcjkrtx.html