20. 有效的括号(Java)

题目描述:

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

有效字符串需满足:

1.左括号必须用相同类型的右括号闭合。

2.左括号必须以正确的顺序闭合。

3.每个右括号都有一个对应的相同类型的左括号。

输入:

s = "()[]{}"

输出:

true

代码实现:

java 复制代码
public class Main{
    public static void main(String[] args) {
        String s = "[()](())";
        System.out.println(isValid(s));//true
    }

    public static boolean isValid(String s) {
        Stack<Character> stack1 = new Stack<>();//存入栈元素
        Stack<Character> stack2 = new Stack<>();//存出栈元素
        for (int i = 0; i < s.length(); i++) {
            stack1.push(s.charAt(i));//将字符串的元素依次压入栈中
        }
        //依次出栈进行匹配 (),[],{}
        while (!stack1.isEmpty()) {
            //若栈2为空,则取栈1 栈顶元素压入
            if (stack2.isEmpty()) {
                stack2.push(stack1.pop());//将从栈1出栈的元素存入栈2
            }
            //若栈1为空,则直接跳出循环,防止空栈异常
            if (stack1.isEmpty()) {
                break;
            }
            Character c1 = stack1.peek();//获取stack1栈顶元素
            Character c2 = stack2.peek();//获取stack2栈顶元素
            //将两栈顶元素进行匹配
            if ((c1 == '(' && c2 == ')') || (c1 == '[' && c2 == ']') || (c1 == '{' && c2 == '}')) {
                //若匹配成功,两栈顶元素均出栈
                stack1.pop();
                stack2.pop();
            } else {
                //如果不匹配,栈1栈顶元素出栈 并压入栈2
                stack2.push(stack1.pop());
            }
        }
        //判断栈2是否为空:若为空,则字符串全部匹配
        return stack2.isEmpty();
    }
}
相关推荐
lead520lyq1 分钟前
Golang Protoc Grpc实现微服务通信
开发语言·微服务·golang
BHXDML1 分钟前
Python:(一)变量、类型与 f-string —— 数据的载体
开发语言·python
JMchen1231 分钟前
Android剪切板工具类ClipBoardUtil:简化剪切板操作
android·java·移动开发·android studio
蒹葭玉树11 分钟前
【C++上岸】C++常见面试题目--操作系统篇(第二十七期)
java·c++·面试
学嵌入式的小杨同学12 分钟前
【Linux 实战】Makefile 自动化构建进阶:静态库 / 动态库通用模板(一键编译 + 系统安装)
linux·开发语言·git·vscode·spring·vim·ux
小孟的CDN14 分钟前
一维热传导方程的PINN求解——损失函数实时绘制
开发语言·python
透明的玻璃杯16 分钟前
VS2015+QT5程序发布
开发语言·qt
蜂蜜黄油呀土豆18 分钟前
深入解析Java虚拟机垃圾回收机制
java·jvm·cms·垃圾回收·g1
爱学习的阿磊22 分钟前
自定义操作符重载指南
开发语言·c++·算法
洛阳纸贵24 分钟前
JAVA高级工程师--RabbitMQ消费者消息限流、超时、死信队列以及若依集成升级
java·rabbitmq·java-rabbitmq