给定一个只包含 ‘(‘ 和 ‘)’ 的字符串,找出最长的包含有效括号的子串的长度。
示例 1:
输入: "(()"
输出: 2
解释: 最长有效括号子串为 "()"
示例 2:
输入: ")()())"
输出: 4
解释: 最长有效括号子串为 "()()"
解:
public int longestValidParentheses(String s) {
Stack<Integer> stack = new Stack<Integer>();
int max = 0;
int left = -1;
for (int j = 0; j < s.length(); j++) {
if (s.charAt(j) == '(') {
stack.push(j);
} else {
if (stack.isEmpty()) {
left = j;
} else {
stack.pop();
if (stack.isEmpty()) {
max = Math.max(max, j - left);
} else {
max = Math.max(max, j - stack.peek());
}
}
}
}
return max;
}