LeetCode笔记:394. Decode String

问题:

Given an encoded string, return it's decoded string.
The encoding rule is: k[encoded_string], where the encoded_string inside the square brackets is being repeated exactly k times. Note that k is guaranteed to be a positive integer.
You may assume that the input string is always valid; No extra white spaces, square brackets are well-formed, etc.
Furthermore, you may assume that the original data does not contain any digits and that digits are only for those repeat numbers, k. For example, there won't be input like 3a or 2[4].
Examples:

s = "3[a]2[bc]", return "aaabcbc".
s = "3[a2[c]]", return "accaccacc".
s = "2[abc]3[cd]ef", return "abcabccdcdcdef".

大意:

给出一个编码了的字符串,返回它的解码字符串。
编码规则是:k[编码字符串],方括号里的编码字符串会重复k次。注意k保证是一个正整数。
你可以假设输入的字符串都是有效的;没有额外的空格,方括号是能够匹配的,等等。
此外,你可以假设原始数据不包含任何数字,数字只用来表示重复次数k。比如,不会有 3a 或者 2[4] 这样的输入。
例子:

s = "3[a]2[bc]", return "aaabcbc".
s = "3[a2[c]]", return "accaccacc".
s = "2[abc]3[cd]ef", return "abcabccdcdcdef".

思路:

这个思路比较直,遍历字符串,遇到数字后,记录下数字,获取方括号内的字符串,重复k次添加到结果字符串中。

需要注意的有两个地方,一个是方括号中可能嵌套重复的内容,所以一是要准确找到左括号对应的右括号是哪个,我们用一个变量来记录遇到的左括号和右括号数量就可以了,二是要用递归来操作内容的重复,因为里面还可能包含着重复的内容需要解码。另一个要注意的是数字不一定是一位数,还可能是多位数,因此当遇到数字后,要看看后面是不是还是数字,是的话要记录下来换算成真正的重复次数。

public class Solution {
    public String decodeString(String s) {
        return decodeSub(s, 1);
    }
    
    public String decodeSub(String sub, int count) {
        String trueStr = "";
        for (int i = 0; i < sub.length(); i++) {
            if (sub.charAt(i) - '1' >= 0 && sub.charAt(i) - '9' <= 0) {
                int subCount = sub.charAt(i) - '0';
                while (sub.charAt(i+1) - '0' >= 0 && sub.charAt(i+1) - '9' <= 0) {
                    i++;
                    subCount = subCount * 10 + sub.charAt(i) - '0';
                }
                
                int start = i+2;
                int num = 1;
                String subsub = "";
                for (i = i+2; i < sub.length(); i++) {
                    if (sub.charAt(i) - '[' == 0) num++;
                    else if (sub.charAt(i) - ']' == 0) num--;
                    
                    if (num == 0) {
                        subsub = sub.substring(start, i);
                        break;
                    }
                }
                trueStr = trueStr + decodeSub(subsub, subCount);
                
            } else {
                trueStr = trueStr + sub.substring(i, i+1);
            }
        }
        String decodeRes = "";
        for (int i = 0; i < count; i++) {
            decodeRes = decodeRes + trueStr;
        }
        return decodeRes;
    }
}

合集:https://github.com/Cloudox/LeetCode-Record


查看作者首页

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,828评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,437评论 18 399
  • 当你时时刻刻知道酒是毒药的时候,你就真正的看到了这个世界。
    启山乐水阅读 1,535评论 0 0
  • 黄岩/文 入夜雨敲窗, 寒蝉窃窃藏。 悄然润万物, 翌日彩蝶忙。
    騒文蕥客阅读 1,486评论 0 1

友情链接更多精彩内容