zoukankan      html  css  js  c++  java
  • [leetcode] 22. 括号生成

    22. 括号生成

    谨慎后,1A的概率貌似高了些
    算是20题的升级版吧,
    利用递归来拼成string,然后通过20. 有效的括号该题的代码来判断生成的string合不合法

    看代码吧

    class Solution {
        public List<String> generateParenthesis(int n) {
            List<String> ans = new ArrayList<>();
            dfs(ans, "", n, n);
            return ans;
        }
    
        public void dfs(List<String> list, String st, int left, int right) {
            if (left == 0 && right == 0 && isValid(st)) {
                list.add(st);
            }
            if (left > 0) dfs(list, st + "(", left-1, right);
            if (right > 0) dfs(list, st + ")", left, right-1);
        }
    
        public boolean isValid(String s) {
            Stack<Character> characterStack = new Stack<>();
    
            for (int i = 0; i < s.length(); i++) {
                switch (s.charAt(i)) {
                    case '(':
                    case '[':
                    case '{':
                        characterStack.push(s.charAt(i));
                        break;
                    case ')':
                        if (!characterStack.isEmpty() && characterStack.peek() == '(') {
                            characterStack.pop();
                            break;
                        } else {
                            return false;
                        }
                    case ']':
                        if (!characterStack.isEmpty() && characterStack.peek() == '[') {
                            characterStack.pop();
                            break;
                        } else {
                            return false;
                        }
                    case '}':
                        if (!characterStack.isEmpty() && characterStack.peek() == '{') {
                            characterStack.pop();
                            break;
                        } else {
                            return false;
                        }
                }
            }
    
            return characterStack.isEmpty();
        }
    }
    

    AC后观摩榜单大神的代码,发现其实不必使用isValid()函数判断合法性,

    只需保证已经生成的字符串中,左括号的数量>=右括号的数量即可,反过来讲剩余待使用左括号数量要<剩余待使用的右括号数量,否则,当前分支剪掉,代码如下

    class Solution {
        public List<String> generateParenthesis(int n) {
            List<String> ans = new ArrayList<>();
            dfs(ans, "", n, n);
            return ans;
        }
    
        public void dfs(List<String> list, String st, int left, int right) {
            if (right < left) return;
            if (left == 0 && right == 0) {
                list.add(st);
            }
            if (left > 0) dfs(list, st + "(", left - 1, right);
            if (right > 0) dfs(list, st + ")", left, right - 1);
        }
    }
    

    尼玛优化后居然比优化前慢5ms,严重怀疑leetcode评测机有毛病,代码跑多久看RP

  • 相关阅读:
    C++解析-外传篇(3):动态内存申请的结果
    C++解析-外传篇(2):函数的异常规格说明
    C++解析-外传篇(1):异常处理深度解析
    C++解析(31):自定义内存管理(完)
    Fisherfaces 算法的具体实现源码
    Philipp Wagner
    人脸识别中截取面部的实现方法
    OpenCV Haar AdaBoost源码改进据说是比EMCV快6倍
    win10系统下载地址
    人脸识别中的检测(在Opencv中加入了QT)
  • 原文地址:https://www.cnblogs.com/acbingo/p/9251617.html
Copyright © 2011-2022 走看看