394. 字符串解码

Difficulty
Medium
Tags
URL
https://leetcode.cn/problems/decode-string/
Star
给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。
你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。
此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a2[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 站模拟

思路
  1. 本题核心思路是在栈里面每次存储两个信息, (左括号前的字符串, 左括号前的数字), 比如abc3[def], 当遇到第一个左括号的时候,压入栈中的是("abc", 3), 然后遍历括号里面的字符串def, 当遇到右括号的时候, 从栈里面弹出一个元素(s1, n1), 得到新的字符串为s1+n1*"def", 也就是abcdefdefdef。对于括号里面嵌套的情况也是同样处理方式。
  1. 凡是遇到左括号就进行压栈处理,遇到右括号就弹出栈,栈中记录的元素很重要。
题解
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