码迷,mamicode.com
首页 > 其他好文 > 详细

【leetcode】32. Longest Valid Parentheses

时间:2016-04-10 01:01:45      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

这题不能使用递归来写,因为有一个输入长度是17173,会爆栈。因此得手动模拟栈调用。

 

public class Solution {
    private static class StackFrame {
        public final char left;
        private int num;
        public StackFrame(char left) {
            this.left = left;
        }
        @Override
        public String toString() {
            return "StackFrame [left=" + left + ", num=" + num + "]";
        }
    }
    
    private static final Stack<StackFrame> stack = new Stack<StackFrame>();
    
    public int longestValidParentheses(String s) {
        stack.clear();
        stack.push(new StackFrame(‘#‘));
        int maxNum = 0;
        
        for (int i = 0; i < s.length(); ++i) {
            char c = s.charAt(i);
            if (isLeft(c)) {
                stack.push(new StackFrame(c));
            } else if (isPair(stack.peek().left, c)) {
                StackFrame frame = stack.pop();
                stack.peek().num += frame.num + 2;
                if (stack.peek().num > maxNum) {
                    maxNum = stack.peek().num;
                }
            } else {
                stack.peek().num = 0;
                if (stack.size() > 1) {
                    while (stack.size() > 1) {
                        stack.pop();
                    }
                }
            } 
        }
        return maxNum;
    }
    
    private boolean isLeft(char c) {
        return c == ‘(‘ || c == ‘[‘ || c == ‘{‘;
    }
    
    private boolean isPair(char left, char right) {
        if (left == ‘(‘) {
            return right == ‘)‘;
        } else if (left == ‘[‘) {
            return right == ‘]‘;
        } else {
            return right == ‘}‘;
        }
    }
}

 

【leetcode】32. Longest Valid Parentheses

标签:

原文地址:http://www.cnblogs.com/lanhj/p/5373071.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!