leetcode *394. 字符串解码(2020.5.28)

这篇博客介绍了LeetCode 394题目的解法,主要探讨了两种不同的解题思路:单栈和双栈策略。通过详细解释编码规则和示例,展示了如何将编码字符串正确解码回原始字符串。在单栈策略中,利用栈处理数字和字符,遇到右括号时将相应内容转化为字符串并压入栈中。而在双栈策略中,分别使用数字栈和字符串栈来处理编码信息。
摘要由CSDN通过智能技术生成

【题目】*394. 字符串解码

给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为: 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”.

【解题思路1】单栈

用栈,碰到数字、字母、左中括号都压入栈中,碰到右括号开始弹出,先弹出拿到字符串,再拿到数字(重复次数),把这一段转成字符串压入栈中,继续执行,最后把栈内存的reverse一下

class Solution {
   
    int ptr;

    public String decodeString(String s) {
   
        LinkedList<String> stk = new LinkedList<String>();
        ptr = 0;

        while (ptr < s.length()) {
   
            char cur = s.charAt(ptr);
            if (Character.isDigit(cur)) {
   
                // 遇到数字,进栈
                String digits = getDigits(s);
                stk.addLast(digits); //addLast()将指定元素追加在此列表的末尾
            } else if (Character.isLetter(cur) || cur == '[') {
   
                // 遇到字母或者左括号,进栈
                stk.addLast(String.valueOf(s.charAt(ptr++))); 
            } else {
   
                ++ptr;
                LinkedList<String> sub = new LinkedList<String>();
                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值