leetcode 最长有效括号

白昼怎懂夜的黑 提交于 2020-02-04 19:27:13

给定一个只包含 '(' 和 ')' 的字符串,找出最长的包含有效括号的子串的长度。

示例 1:

输入: "(()"
输出: 2
解释: 最长有效括号子串为 "()"
示例 2:

输入: ")()())"
输出: 4
解释: 最长有效括号子串为 "()()"

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-valid-parentheses
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
public:
    //令(为1,)为-1
    //1.括号的匹配情况是一定的,当前缀和小于0的时候说明当前括号没法在前面匹配,直接跳过
    //2.需要正向反向遍历
    int longestValidParentheses(string s) {
        if(s.empty())return 0;
        int res=0;
        for(int i=0,cot=0,start=0;i<s.size();++i){
            if(s[i]=='(')cot++;
            else{
                cot--;
                if(cot==0){
                    res=max(res,i-start+1);
                }
                else if(cot<0){
                    start=i+1;
                    cot=0;
                }
            }
        }
        for(int i=s.size()-1,cot=0,start=s.size()-1;i>=0;--i){
            if(s[i]==')')cot++;
            else{
                cot--;
                if(cot==0){
                    res=max(res,start-i+1);
                }
                else if(cot<0){
                    start=i-1;
                    cot=0;
                }
            }
        }
        return res;
    }
};
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!