首页 > 代码库 > LeetCode Longest Valid Parentheses
LeetCode Longest Valid Parentheses
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.
1 public class Solution { 2 public int longestValidParentheses(String s) { 3 if (s == null) { 4 return 0; 5 } 6 int maxlen=0; 7 Stack<Integer> stack = new Stack<Integer>(); 8 stack.add(-1); 9 for (int i = 0; i < s.length(); i++) {10 if (s.charAt(i) == ‘(‘) {11 stack.add(i);12 } else {13 stack.pop();14 if (stack.isEmpty()) {15 stack.add(i);16 } else {17 maxlen=Math.max(maxlen,i-stack.peek());18 } 19 }20 }21 return maxlen;22 }23 }
LeetCode Longest Valid Parentheses
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。