Java括号匹配

简介: Java括号匹配



一、题目描述

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

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

示例:

输入:s = "()"

输出:true

输入:s = "(]"

输出:false

二、题解

思路分析:

我们可以使用来解决这个问题:

遍历字符串,如果是左括号,就将其入栈

如果是右括号,就将栈顶元素弹出,判断是否是与其匹配的左括号,

若栈中无元素可以弹出,则无能与该右括号匹配的左括号,返回false,

若不是与其匹配的左括号,返回false,

若是与其匹配的左括号,则继续遍历下一个字符。

当循环结束时,判断栈是否为空,

若栈不为空,则表明还有未匹配的左括号,返回false,

若栈为空,则表示所有的左括号都与相同类型的右括号匹配,返回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 == '(' || ch == '[' || ch == '{'){
                stack.push(ch);
            }else {
                //右括号,出栈
                //无左括号能够匹配,返回false
                if(stack.empty()){
                    return false;
                }
                char ch2 = stack.pop();
                if((ch2 == '(' && ch == ')') || (ch2 == '[' && ch == ']') || (ch2 == '{' && ch == '}')){
                    
                }else {
                    return false;
                }
            }
        }
        return stack.empty();
    }
}

题目来自:

20. 有效的括号 - 力扣(LeetCode)

目录
相关文章
|
8天前
|
Java
|
8天前
|
Java 程序员 索引
括号在 Java 编程中的作用详解
括号在 Java 编程中的作用详解
81 0
|
8天前
|
C++ Rust NoSQL
Rust 数据类型 之 类C枚举 c-like enum
Rust 数据类型 之 类C枚举 c-like enum
35 0
Rust 数据类型 之 类C枚举 c-like enum
|
8天前
|
算法 Python Java
Java每日一练(20230429) 二叉树后序遍历、删除无效括号、合并有序链表
Java每日一练(20230429) 二叉树后序遍历、删除无效括号、合并有序链表
30 0
Java每日一练(20230429) 二叉树后序遍历、删除无效括号、合并有序链表
|
8天前
|
Python Java 算法
Java每日一练(20230402) 有效括号、二叉树前序遍历、全排列
Java每日一练(20230402) 有效括号、二叉树前序遍历、全排列
30 0
Java每日一练(20230402) 有效括号、二叉树前序遍历、全排列
|
8天前
|
Python Java Go
Java每日一练(20230401) 合并K个升序链表、最长有效括号、分割回文串
Java每日一练(20230401) 合并K个升序链表、最长有效括号、分割回文串
24 0
Java每日一练(20230401) 合并K个升序链表、最长有效括号、分割回文串
|
8天前
|
Java
括号匹配问题使用Java实现~
括号匹配问题使用Java实现~
|
8天前
|
Java
22. 括号生成 --力扣 --JAVA
数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。
33 0
|
9月前
|
Java
有效括号序列(java实现
有效括号序列(java实现
|
存储 算法 Java
【算法练习】有趣的括号匹配问题(思路+ 图解 +优化)基于java实现
1.题目描述 小洛看着一堆只包含’(‘和’)‘的括号序列犯愁了,小洛想知道这串序列里最长正确匹配的序列长度是多少,你能帮帮小洛吗?
【算法练习】有趣的括号匹配问题(思路+ 图解 +优化)基于java实现