zoukankan      html  css  js  c++  java
  • Leetcode32. 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.

    solution:用stack,复杂度O(n)

    package leetcode2;
    
    import java.util.Stack;
    
    public class LongestValid_Parentheses {
        public static int longest_VP_DP(String s) {
            Stack<Integer> re =new Stack<Integer>();
            int start=-1;
            int maxl=0;
            int location;
            for(int i=0;i<s.length();i++){
                if (s.charAt(i)=='('){
                    re.push(i);
                }else{
                    if(re.empty()){
                        start=i;
                    }else{
                    location=re.pop();
                    if(re.empty()){
                        maxl=Math.max(maxl, i-start); //外围没有(括号了,到i已得到一个局部最大值
                    }else{
                        maxl=Math.max(maxl, re.peek()-i);  //外围还有(,没有结束哦
                    }
                    }
                }
                
            }
            return maxl;
            
        }
        public static void main(String[] args) {
            // TODO Auto-generated method stub
        String string="()()(";
        System.out.println(longest_VP_DP(string));
        }
    
    }
  • 相关阅读:
    KETTLE:mongdb与mysql互传数据
    6.azkban的监控
    5.azkaban权限管理
    3.azkaban3.0测试
    2.azkaban3.0安装
    1.编译azkaban
    十六:The YARN Service Registry
    十四:Using CGroups with YARN
    十二:NodeManager
    十 Writing YARN Applications
  • 原文地址:https://www.cnblogs.com/joannacode/p/4389328.html
Copyright © 2011-2022 走看看