栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

Leetcode-394

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Leetcode-394


https://leetcode-cn.com/problems/decode-string/

给定一个经过编码的字符串,返回它解码后的字符串。

编码规则为: 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".

比较简单 递归比较慢

class Solution {

public:

    string decodeString(string s) 

{

    string numstr;

    int nstr = 0;

    string yjd;

    for (; s[nstr]; nstr++)

    {

        if (isdigit(s[nstr]))

        {

            if(nstr!=0)

            yjd = s.substr(0, nstr);

            numstr = s.substr(nstr, s.find('[')-nstr);

            break;

        }

    }

    if (nstr == s.size())

        return s;

    int numz = atoi(numstr.data());

    string subz;

    int A = 0;

    int B = 0;

    int C = 0;

    int D = 0;

    string str,ls;

    stack lskh;

    while (s[A])

    {

        if (s[A]=='[')

        {

            B++;

            lskh.push(A);

        }

        if (s[A] == ']')

        {

            B--;

            C = lskh.top();

            lskh.pop();

        }

        if (B == 0 && s[A] == ']')

        {

             subz = s.substr(C + 1, A-(C+1));

             ls = decodeString(subz);

            for (D = 0; D < numz; D++)

            {

                str += ls;

            }

            ls = yjd + str;

            if (A == s.size() - 1)

            {

                break;

            }

            else

            {

                ls += decodeString(s.substr(A+1,s.size()-(A+1)));

            }

            break;

        }

        A++;

    }

    return ls;

}

};

©著作权归作者所有:来自51CTO博客作者hzChan的原创作品,如需转载,请注明出处,否则将追究法律责任


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/232695.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号