描述
给出一个长度为 n 的,仅包含字符 '(' 和 ')' 的字符串,计算最长的格式正确的括号子串的长度。
例1: 对于字符串 "(()" 来说,最长的格式正确的子串是 "()" ,长度为 2 .
例2:对于字符串 ")()())" , 来说, 最长的格式正确的子串是 "()()" ,长度为 4 .
字符串长度:0≤n≤1×1050 \le n \le 1\times10^50≤n≤1×105
要求时间复杂度 O(n)O(n)O(n) ,空间复杂度 O(n)O(n)O(n).
示例1
输入:
"(()"
返回值:
2
示例2
输入:
"(())"
返回值:
4
class Solution {
public:
int longestValidParentheses(string s) {
if(s.length()==0) return 0;
int i,N=s.length(),Max=0;
vector<int> dp(N,0);
for(i=N-2;i>=0;i--)
{
if(s[i]==')') dp[i]=0;
else
{
int j=i+1+dp[i+1];
if(j<N&&s[j]==')')
{
dp[i]=dp[i+1]+2;
if(j+1<N) dp[i]+=dp[j+1];
}
}
Max=max(Max,dp[i]);
}
return Max;
}
};