【LeetCode 75】第二十六题(394)字符串解码

目录

题目:

示例:

分析:

代码+运行结果:


题目:

示例:

分析:

给我们字符串,让我们解码,那么该怎么解码呢,被括号【】包裹起来的字符串需要扩展成括号左边第一个数字(可能不止一位数)倍,例如 3【a】需要变成 aaa。

我们可以发现,如果发现括号嵌套(括号里还有括号),那么我们应该先算最里面的括号,这样解码才是正确的,换一个说法,我们应该先解码左括号更后面出现的,这就算是先进后出,后进先出了,不难想到可以利用栈的特性来做。

先遍历字符串,我们直接将非右括号的字符全部入栈,直到遇到了右括号才开始解码。

遇到右括号之后一直取栈顶元素直到碰到左括号,这样我们就算是把需要扩展的字符串拿到手了。

接着我们需要拿到扩展字符串的次数,因为题目说扩展次数最多是300次,因此我们不能只取左括号左边的一位数字,而需要一直取数直到栈空或是碰到了非数字。

然后得到扩展的字符串和扩展次数以后,将扩展后的字符串再依次入栈。

如此循环,即可得到解码后的字符串了。

代码+运行结果:

cpp 复制代码
class Solution {
public:
    string decodeString(string s) {
        vector<char>Stack;
        for(char &c:s){
            if(c==']'){ //如果碰到右括号,那么开始寻找是哪些字符串需要解码
                string tempstr="";
                while((*(Stack.end()-1))!='['){ //获取括号内的字符串
                    tempstr=(*(Stack.end()-1))+tempstr; 
                    Stack.pop_back();
                }
                Stack.pop_back();   //将左括号[弹出
                int times=0;int beishu=0;   //获取重复次数
                while(!Stack.empty()&&isdigit(*(Stack.end()-1))){
                    times+=(pow(10,beishu++)*(static_cast<int>((*(Stack.end()-1)-'0'))));
                    Stack.pop_back();
                }  
                //开始解码字符串(重复字符串)
                for(int i=0;i<times;i++){
                    for(char &t:tempstr){
                        Stack.push_back(t);
                    }
                }
            }else{  //除了右括号以外的其他符号都入栈
                Stack.push_back(c);
            }
        }
        string res="";
        //拼接最终结果
        for(char &c:Stack) res+=c;
        return res;
    }
};
相关推荐
生成论实验室6 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第一篇:生成正在发生——从《即事经》到事件-关系网络
人工智能·科技·算法·架构·创业创新
漂流瓶jz10 分钟前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva
leoufung18 分钟前
LeetCode 76:Minimum Window Substring 题解与滑动窗口思维详解
算法·leetcode·职场和发展
小O的算法实验室31 分钟前
2026年IEEE TETCI,山区环境下基于双种群进化的协同无人机巡逻任务协同优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
A7bert77739 分钟前
【YOLOv8pose部署至RDK X5】模型训练→转换bin→Sunrise 5部署
c++·python·深度学习·yolo·目标检测
你撅嘴真丑44 分钟前
map 与 set容器的应用--话题焦点人物
数据结构
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
li1670902701 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
风筝在晴天搁浅1 小时前
字节高频题 小于n的最大数
算法
LabVIEW开发1 小时前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序