Longest Valid Parentheses

Given a string containing just the characters '(' and ')', return the length of the longest valid (well-formed) parentheses substring.



Example 1:

      Input: s = "(()"
      Output: 2
      Explanation: The longest valid parentheses substring is "()".
      

Example 2:

      Input: s = ")()())"
      Output: 4
      Explanation: The longest valid parentheses substring is "()()".
      

Example 3:

      Input: s = ""
      Output: 0
      


Constraints:

  • 0 <= s.length <= 3 * 104
  • s[i] is either '(' or ')'
C++

Test Cases

1
2
3

Test Case 1

Input : s = ")()())"

Expected Output : 4

Test Case 2

Input : s = "(()"

Expected Output : 2

Test Case 3

Input : s = ""

Expected Output : 0