Valid Parentheses

本文介绍了一种使用栈实现的有效括号匹配算法。通过遍历输入字符串并利用栈来跟踪括号,确保每一对括号正确闭合。文章详细解释了算法流程,并提供了一个Java示例实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目的意思一开始没看明白,以为括号是有优先级的,想的太复杂了,输入的字符串只包含括号。

最内层的括号必须是相邻的,类似{ ( [ ] ) }也是有效的。

用栈来实现。

如果字符串长度为奇数,肯定不是有效的。

遍历字符串,如果遇到前半部分括号,则把后半部分的括号入栈。

下一次遍历时,如果不是前半部分括号,即是后半部分,那么就得要判断与前一个字符是否匹配,

判断栈是否为空,不为空,把该字符与栈顶元素比较,不相同,返回false;相同,将栈顶出栈。

遍历全部结束后,判断栈是否为空,返回判断值。

注意:Java中Stack中只能存放对象,不能存放基本数据类型,char对应的封装类是Character

public boolean isValid(String s) {
        int length = s.length();
        if(length == 0)return true;
        if(length%2 != 0)return false;
        Stack<Character> stack = new Stack<Character>();
        
        for(int i=0;i<length;i++){
            char c = s.charAt(i);
            if(c=='(')stack.push(')');
            else if(c=='[')stack.push(']');
            else if(c=='{')stack.push('}');
            else if(!stack.empty()){
                if(c!=stack.peek())return false;
                else stack.pop();
            }
        }
        return stack.empty();
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值