LeetCode:394. Decode String(解析字符串)

文章最前: 我是Octopus,这个名字来源于我的中文名--章鱼;我热爱编程、热爱算法、热爱开源。

这博客是记录我学习的点点滴滴,如果您对 Python、Java、AI、算法有兴趣,可以关注我的动态,一起学习,共同进步。

相关文章:

  1. LeetCode:55. Jump Game(跳远比赛)
  2. Leetcode:300. Longest Increasing Subsequence(最大增长序列)
  3. LeetCode:560. Subarray Sum Equals K(找出数组中连续子串和等于k)

目录结构:

题目描述:

java实现方法1:

python实现方式1:

源码地址:


题目描述:

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

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

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

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

示例:

s = "3[a]2[bc]", 返回 "aaabcbc".
s = "3[a2[c]]", 返回 "accaccacc".
s = "2[abc]3[cd]ef", 返回 "abcabccdcdcdef".

来源:力扣(LeetCode)


java实现方法1:

   /**
     * 解析字符串
     *
     * @param s 输入字符
     * @return 解析后字符串
     */
    public String decodeString(String s) {
        char[] t = s.toCharArray();
        int i = 0, n = s.length();
        StringBuilder sb = new StringBuilder();
        while (i < n) {
            int idx = s.indexOf('[', i);
            if (idx == -1) {
                sb.append(s.substring(i));
                break;
            }
            while (t[i] < '0' || t[i] > '9') {
                sb.append(t[i]);
                i++;
            }
            int len = Integer.valueOf(s.substring(i, idx));
            int count = 1;
            i = idx + 1;
            while (count != 0) {
                if (t[i] == '[') count++;
                if (t[i] == ']') count--;
                i++;
            }
            String sub = decodeString(s.substring(idx + 1, i - 1));
            for (int k = 0; k < len; k++)
                sb.append(sub);
        }
        return sb.toString();
    }

时间复杂度:O(n^2)

空间复杂度:O(n)


python实现方式1:

def decode_string(s: str) -> str:
    '''
        解析字符串
    Args:
        s: 字符串
    Returns:
        解析后的字符串
    '''
    i = 0
    n = len(s)
    sb = []
    while i < n:
        idx = s.index('[',i)
        if idx == -1:
            sb.append(s[i:])
            break
        while s[i] < '0' or s[i] > '9':
            sb.append(s[i])
            i += 1
        length = int(s[i:idx])
        count = 1
        i = idx + 1
        while count != 0:
            if s[i] == '[':
                count += 1
            if s[i] == ']':
                count -= 1
            i += 1
        sub = decode_string(s[idx + 1:i - 1])
        for k in range(length):
            sb.append(sub)
    return ''.join(sb)

时间复杂度:O(n^2)

空间复杂度:O(n)


源码地址:

https://github.com/zhangyu345293721/leetcode

你可能感兴趣的:(LeetCode)