Q394 字符串解码

给定一个经过编码的字符串,返回它解码后的字符串。

编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。

你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。

此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a2[4] 的输入。

示例:

s = "3[a]2[bc]", 返回 "aaabcbc".
s = "3[a2[c]]", 返回 "accaccacc".
s = "2[abc]3[cd]ef", 返回 "abcabccdcdcdef".
class Solution {
    public String decodeString(String s) {
        if (s == null || s.length() == 0)
        return "";

        if (s.indexOf('[') == -1)
            return s;

        char[] chs = s.toCharArray();
        int idx = 0;
        StringBuilder sb = new StringBuilder();

        for (; idx < chs.length; idx++){
            if (!(chs[idx] <= 57 && chs[idx] >= 48))
                sb.append(chs[idx]);
            else {
                int start = s.indexOf('[', idx);
                int k = Integer.valueOf(s.substring(idx, start));

                idx = start + 1;
                int m = 1;
                for (; idx < chs.length; idx++) {
                    if (chs[idx] == '[')
                        m++;
                    else if (chs[idx] == ']')
                        m--;

                    if (m == 0)
                        break;
                }

                String temp = decodeString(s.substring(start + 1, idx));
                while (k-- > 0)
                    sb.append(temp);
            }
        }

        return sb.toString();
    }
}
posted @ 2019-04-19 14:44  围城DDD  阅读(128)  评论(0编辑  收藏  举报