栈的应用之最长匹配括号长度

最长匹配括号长度

主要介绍栈的一个应用,之前做过类似的题目,这次彻底搞懂,记录之。。

找到最长匹配括号长度,这题比较难,之前刷题的时候就觉得,这次学到了。
比如说()()()(((最长匹配括号长度为6,((())最长匹配括号长度是4。

1.如果是左括号肯定是压栈(压入该左括号在串中的索引)。
2.如果是右括号:
那么就要分两种情况:
第一种情况是栈不为空,说明找到了匹配的左括号,那么记录当前匹配左括号的长度,并且并且弹栈,弹栈以后又分为两种情况:
(1)栈为空,说明本次匹配完成,用当前索引减去start索引
(2)栈不为空,则当前匹配长度=当前索引-栈顶元素索引
第二种情况是栈为空,说明之前已经匹配完了,那么设置当前右括号的位置为新的匹配起点开始记录。

class Solution {
public:
    int longestValidParentheses(string s) {
        stack<int> ss;
        int start = -1;
        int size=s.size();
        int m=0;
        for(int i=0;i<size;++i)
        {
            if(s[i]=='(')//left push
            {
                ss.push(i);
            }
            else
            {
                if(ss.empty())
                {
                    start=i;
                }
                else
                {
                    ss.pop();
                    if(ss.empty())
                    {
                        m=max(i-start,m);
                    }
                    else
                    {
                        m=max(m,i-ss.top());
                    }
                }
            }
        }
        return m;
    }
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值