题目描述
给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为: k[encoded_string]
,表示其中方括号内部的 encoded_string
正好重复 k
次。注意 k
保证为正整数。
你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。
此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k
,例如不会出现像 3a
或 2[4]
的输入。
示例 1:
1 2
| 输入:s = "3[a]2[bc]" 输出:"aaabcbc"
|
示例 2:
1 2
| 输入:s = "3[a2[c]]" 输出:"accaccacc"
|
示例 3:
1 2
| 输入:s = "2[abc]3[cd]ef" 输出:"abcabccdcdcdef"
|
示例 4:
1 2
| 输入:s = "abc3[cd]xyz" 输出:"abccdcdcdxyz"
|
提示:
1 <= s.length <= 30
s
由小写英文字母、数字和方括号 '[]'
组成
s
保证是一个 有效 的输入。
s
中所有整数的取值范围为 [1, 300]
解法
- 栈操作
- 准备两个栈,一个存放数字,一个存放字符串
- 遍历字符串分4中情况
- 如果是数字 将字符转成整型数字 注意数字不一定是个位 有可能是十位,百位等 所以digit = digit*10 + ch - ‘0’;
- 如果是字符 直接将字符放在临时字符串中
- 如果是”[“ 将临时数字和临时字符串入栈
- 如果是”]” 将数字和字符串出栈 此时临时字符串res = 出栈字符串 + 出栈数字*res
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
| class Solution { public String decodeString(String s) { Deque<Integer> digitStack=new LinkedList<>(); Deque<StringBuilder> stringsStack=new LinkedList<>(); int digit=0; StringBuilder res=new StringBuilder(); for (int i = 0; i < s.length(); i++) { char theChar=s.charAt(i); if (theChar=='['){ digitStack.push(digit); stringsStack.push(res); digit=0; res=new StringBuilder(); }else if (theChar==']'){ int count=digitStack.poll(); StringBuilder temp=stringsStack.poll(); for (int j = 0; j < count; j++) { temp.append(res.toString()); } res=temp; }else if (Character.isDigit(theChar)){ digit=digit*10+theChar-'0'; }else { res.append(theChar); } } return res.toString(); } }
|
来源:力扣(LeetCode)
链接:394. 字符串解码 - 力扣(LeetCode)