【Leetcode 热题 100】394. 字符串解码

问题背景

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

编码规则为: k [ e n c o d e d _ s t r i n g ] k[encoded\_string] k[encoded_string],表示其中方括号内部的 e n c o d e d _ s t r i n g encoded\_string encoded_string 正好重复 k k k 次。注意 k k k 保证为正整数。

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

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

数据约束

  • 1 ≤ s . l e n g t h ≤ 30 1 \le s.length \le 30 1≤s.length≤30
  • s s s 由小写英文字母、数字和方括号 '[]' 组成
  • s s s 保证是一个 有效 的输入
  • s s s 中所有整数的取值范围为 [ 1 , 300 ] [1, 300] [1,300]

解题过程

这题标签是中等,但还是比较复杂的。

从一般的思路来说,它是一个从里到外的过程。

因为有可能出现嵌套使用 k [ e n c o d e d _ s t r i n g ] k[encoded\_string] k[encoded_string] 这个规则的可能,所以有必将已经完成解析的字符串记录到栈中。

在这个基础上,遇到不同的字符进行相应的处理即可。

具体实现

java 复制代码
class Solution {
    public String decodeString(String s) {
        // 定义两个栈,一个用来记录系数,一个用来记录已经完成解析的字符串
        Deque<Integer> integerStack = new ArrayDeque<>();
        Deque<String> stringStack = new ArrayDeque<>();
        int times = 0;
        StringBuilder stringBuilder = new StringBuilder();
        for(char c : s.toCharArray()) {
            // 在当前处理过程中,按数位顺序计算系数
            if(Character.isDigit(c)) {
                times = times * 10 + c - '0';
            }
            // 遇到左括号,将当前的字符串记录到栈中
            if(c == '[') {
                integerStack.push(times);
                times = 0;
                stringStack.push(stringBuilder.toString());
                stringBuilder.setLength(0);
            }
            // 遇到右括号,根据题意重复字符串,并对当前处理的字符串进行更新
            if(c == ']') {
                StringBuilder cur = new StringBuilder();
                int curTimes = integerStack.pop();
                for(int i = 0; i < curTimes; i++) {
                    cur.append(stringBuilder);
                }
                stringBuilder = new StringBuilder(stringStack.pop() + cur);
            }
            // 在当前处理过程中,英文字母直接添加到末尾
            if(Character.isLetter(c)) {
                stringBuilder.append(c);
            }
        }
        return stringBuilder.toString();
    }
}
相关推荐
PPPPPaPeR.15 分钟前
光学算法实战:深度解析镜片厚度对前后表面折射/反射的影响(纯Python实现)
开发语言·python·数码相机·算法
看我干嘛!19 分钟前
python第五次作业
算法
历程里程碑25 分钟前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
Sheep Shaun27 分钟前
如何让一个进程诞生、工作、终止并等待回收?——探索Linux进程控制与Shell的诞生
linux·服务器·数据结构·c++·算法·shell·进程控制
Pluchon28 分钟前
硅基计划4.0 简单模拟实现AVL树&红黑树
java·数据结构·算法
生锈的键盘37 分钟前
推荐算法实践:交叉特征的理解
算法
小龙报43 分钟前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机
dllxhcjla1 小时前
数据结构和算法
数据结构
乌萨奇也要立志学C++1 小时前
【洛谷】BFS 求解最短路:从马的遍历到迷宫问题的实战解析
算法·宽度优先
老鼠只爱大米1 小时前
LeetCode经典算法面试题 #46:全排列(回溯、交换、剪枝等五种实现方案详细解析)
算法·leetcode·剪枝·回溯·全排列·stj算法