算法真题-腾讯-压缩算法(1)

今天刷到了一题腾讯的算法真题,觉得比较有趣,所以在这里和大家分享一下。本题的链接是:压缩算法

题目

小Q想要给他的朋友发送一个神秘字符串,但是他发现字符串的过于长了,于是小Q发明了一种压缩算法对字符串中重复的部分进行了压缩,对于字符串中连续的m个相同字符串S将会压缩为[m|S](m为一个整数且1<=m<=100),例如字符串ABCABCABC将会被压缩为[3|ABC],现在小Q的同学收到了小Q发送过来的字符串,你能帮助他进行解压缩么?

输入

输入第一行包含一个字符串s,代表压缩后的字符串。
S的长度<=1000;
S仅包含大写字母、[、]、|;
解压后的字符串长度不超过100000;
压缩递归层数不超过10层;

输出

输出一个字符串,代表解压后的字符串。

输入例子

HG[3|B[2|CA]]F

输出例子

HGBCACABCACABCACAF

例子说明

HG[3|B[2|CA]]F−>HG[3|BCACA]F−>HGBCACABCACABCACAF

题目分析

这题是一个字符串操作类型的题目,问题的难点在于中括号的范围不确定,中括号也能放其他的中括号,所以我们要从最里面的中括号开始,一层一层剥开,举例说明:上面的例子[3|B[2|CA]],我们很难将[3|*]直接展开,这样会导致有更多的中括号[B[2|CA]B[2|CA]B[2|CA]],从而使问题更加复杂,就像例子说明1里面讲到的,要先从[2|CA]开始展开,这样才能使得中括号个数越来越少从而解决问题。

解题思路

思路是在遍历字符串的过程中,利用一个堆栈,存储"[""|"的位置,当遇到"]"时,他必定与堆栈最上面的"[""|"匹配,可以将他们出栈,然后用到"[""]"中间的值去替换待返回的字符串

代码

public static void main(String args[]){
//        用户输入
        Scanner scanner = new Scanner(System.in);
        String s = scanner.next();
//        用StringBuilder存储结果,一般字符串的拼接都用它,而不是String
        StringBuilder result = new StringBuilder();
//        用堆栈存储[和|的下标
        Stack<Integer> stack = new Stack<>();
        int right = 0;
        for(char ch:s.toCharArray()){
            result.append(ch);
            if(ch == '[' || ch == '|')
                stack.push(right);
//            当前的字符是],就可以将堆栈里面的[和|弹出来了
            if(ch == ']'){
                if(stack.size() >= 2){
                    int shuhao = stack.pop();
                    int zuokuohao = stack.pop();

//                    将[geshu|st]转变成字符串的形式
                    String st = result.substring(shuhao+1, right);
                    int geshu = Integer.parseInt(result.substring(zuokuohao+1,shuhao));
                    StringBuilder dangqian = new StringBuilder();
                    while(geshu-->0){
                        dangqian.append(st);
                    }
//                    将转换后的字符串变为结果的一部分
                    result.replace(zuokuohao,right+1,dangqian.toString());
//                    right下标指向当前result的最后一个字符
                    right = zuokuohao + dangqian.length() - 1;
                }else{
                    System.out.println("您的输入错误!!!");
                }
            }
            right++;

        }
        if(!stack.isEmpty())
            System.out.println("不是对的哦!!!");
        System.out.println(result.toString());
    }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容