zoukankan      html  css  js  c++  java
  • 1087. Brace Expansion

    A string S represents a list of words.

    Each letter in the word has 1 or more options.  If there is one option, the letter is represented as is.  If there is more than one option, then curly braces delimit the options.  For example, "{a,b,c}" represents options ["a", "b", "c"].

    For example, "{a,b,c}d{e,f}" represents the list ["ade", "adf", "bde", "bdf", "cde", "cdf"].

    Return all words that can be formed in this manner, in lexicographical order.

    Example 1:

    Input: "{a,b}c{d,e}f"
    Output: ["acdf","acef","bcdf","bcef"]
    

    Example 2:

    Input: "abcd"
    Output: ["abcd"]
    

    Note:

    1. 1 <= S.length <= 50
    2. There are no nested curly brackets.
    3. All characters inside a pair of consecutive opening and ending curly brackets are different.

    classical dfs

    time = O(2^n), n -- # of pair of braces, space = O(n)

    class Solution {
        public String[] expand(String S) {
            if(S == null || S.length() == 0) {
                return new String[0];
            }
            List<String> list = new ArrayList<>();
            
            dfs(S, 0, new StringBuilder(), list);
            
            String[] res = new String[list.size()];
            for(int i = 0; i < list.size(); i++) {
                res[i] = list.get(i);
            }
            return res;
        }
        
        public void dfs(String s, int idx, StringBuilder sb, List<String> list) {
            if(idx == s.length()) {
                list.add(sb.toString());
                return;
            }
            int len = sb.length();
            
            if(s.charAt(idx) == '{') {
                List<Character> tmp = new ArrayList<>();
                int end = idx + 1;
                while(end < s.length() && s.charAt(end) != '}') {
                    if(Character.isLetter(s.charAt(end))) {
                        tmp.add(s.charAt(end));
                    }
                    end++;
                }
                Collections.sort(tmp);
                for(char c : tmp) {
                    sb.append(c);
                    dfs(s, end + 1, sb, list);
                    sb.setLength(len);
                }
            } else if(Character.isLetter(s.charAt(idx))) {
                sb.append(s.charAt(idx));
                dfs(s, idx + 1, sb, list);
            }
        }
    }
  • 相关阅读:
    IOS AutoLayout 代码实现约束—VFL
    理解iOS Event Handling
    一些优秀的iOS第三方库
    iOS中NSNotification、delegate、KVO三者之间的区别与联系?
    laravel 框架加载自定义函数/类文件
    Nodejs 使用 socket.io 简单实现实时通信
    Redis 与 Memcache 的异同之处
    Redis 服务安装
    PHP 依赖管理神器 Composer 基本使用
    Ajax无刷新图片插件使用
  • 原文地址:https://www.cnblogs.com/fatttcat/p/11220154.html
Copyright © 2011-2022 走看看