394. 字符串解码
Difficulty
Medium
Tags
栈
URL
https://leetcode.cn/problems/decode-string/
Star
给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为:
k[encoded_string]
,表示其中方括号内部的 encoded_string
正好重复 k
次。注意 k
保证为正整数。你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。
此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数
k
,例如不会出现像 3a
或 2[4]
的输入。示例 1:
输入:s = "3[a]2[bc]" 输出:"aaabcbc"
示例 2:
输入:s = "3[a2[c]]" 输出:"accaccacc"
示例 3:
输入:s = "2[abc]3[cd]ef" 输出:"abcabccdcdcdef"
示例 4:
输入:s = "abc3[cd]xyz" 输出:"abccdcdcdxyz"
提示:
1 <= s.length <= 30
s
由小写英文字母、数字和方括号'[]'
组成
s
保证是一个 有效 的输入。
s
中所有整数的取值范围为[1, 300]
通过次数197,973提交次数349,705
法1 站模拟
思路
- 本题核心思路是在栈里面每次存储两个信息, (左括号前的字符串, 左括号前的数字), 比如
abc3[def]
, 当遇到第一个左括号的时候,压入栈中的是("abc", 3)
, 然后遍历括号里面的字符串def
, 当遇到右括号的时候, 从栈里面弹出一个元素(s1, n1)
, 得到新的字符串为s1+n1*"def"
, 也就是abcdefdefdef
。对于括号里面嵌套的情况也是同样处理方式。
- 凡是遇到左括号就进行压栈处理,遇到右括号就弹出栈,栈中记录的元素很重要。
题解
class Solution: def decodeString(self, s: str) -> str: stack = [] num = 0 res = '' # 实时记录当前可以提取出来的字符串 for char in s: if char.isdigit(): num = num * 10 + int(char) elif char == "[": stack.append([res, num]) res, num = '', 0 elif char == "]": top = stack.pop() res = top[0] + res * top[1] else: res += char return res