Given a string containing just the characters ‘(‘
and ‘)‘
, find the length of the longest valid (well-formed) parentheses substring.
For "(()"
, the longest valid parentheses substring is "()"
, which has length = 2.
Another example is ")()())"
, where the longest valid parentheses substring is "()()"
, which has length = 4.
Dynamic Programming String
#include <string> #include <iostream> #include <vector> using namespace std; class Solution { public: int longestValidParentheses(string s) { int len = s.length(); if(len<1) return 0; vector<int > table(len+1,0); int cnt = 0; if(s[0]==‘(‘) cnt++; else cnt --; int retMax = 0; for(int i=1;i<len;i++){ if(s[i]==‘(‘){ if(cnt<0) cnt=1; else cnt++; continue; } cnt--; if(cnt>=0){ if(s[i-1]==‘(‘) table[i+1] = table[i-1]+2; else{ if(s[i-1-table[i]]==‘(‘) table[i+1] = table[i-1-table[i]]+2+table[i]; } if(retMax<table[i+1]) retMax = table[i+1]; } } return retMax; } }; int main() { Solution sol; cout<<sol.longestValidParentheses("()(())")<<endl; return 0; }
[LeetCode] Longest Valid Parentheses 动态规划
原文:http://www.cnblogs.com/Azhu/p/4416027.html