好题记录 Leetcode 394.字符串解码 中等难度

方法一:递归

思路很简单,比较好理解,注意细节处理!!!

cpp 复制代码
class Solution {
public:
    string decodeString(string s) {
        string ans;
        for(int i=0;s[i]!=0;i++){
            if(s[i]>='a'&&s[i]<='z')
               ans+=s[i];
            if(s[i]>='0'&&s[i]<='9'){
                int times=0;
                while(s[i]>='0'&&s[i]<='9'){
                    times=times*10+s[i]-'0';
                    i++;
                } //结束时i的位置是'['
                int pos=i+1;//i+1为这组[]内的第一个元素
                int flag=1;  //存在某个[没有配对的时候 flag为1,每一对左右括号都配对后flag=0
                while(flag){
                    i++;
                    if(s[i]=='[')   flag++;
                    if(s[i]==']')   flag--;
                }//这个循环结束时i的位置是配对结束时']'的位置
                string tmp=decodeString(s.substr(pos,i-pos));
                for(int j=0;j<times;j++)
                    ans+=tmp;
            }
        }
        return ans;
    }
};

方法二:数字栈与字符串栈

cpp 复制代码
class Solution {
public:
    string decodeString(string s) {
        string res="";
        stack<int> nums;
        stack<string> strs;
        int times=0;  //记录次数
        for(int i=0;i<s.size();i++){
            if(s[i]>='a'&&s[i]<='z')  //a-z直接加入res后
               res+=s[i];
            else if(s[i]>='0'&&s[i]<='9'){  //碰到0-9化成次数,数字可能连续好几位要注意
                times=times*10+s[i]-'0'; 
            }
            else if(s[i]=='['){      //碰到左括号[,将当前res和当前times各自入栈,并分别置空和置0
                nums.push(times);
                strs.push(res);
                times=0;
                res="";
            }
            else {   //碰到右括号]时,操作如下
                int tmp=nums.top();  //数字栈的栈顶元素表示次数tmp,然后出栈
                nums.pop();    
                while(tmp--)  strs.top()+=res; //将当前res添加tmp次到字符串栈的栈顶后,再赋给res后出栈
                res=strs.top();    //之后若还是字母,就会直接加到res之后,因为它们是同一级的运算
                                  //若是左括号,res会被压入strs栈,作为上一层的运算
                strs.pop();
            }
        }
        return res;
    }
};
相关推荐
无敌最俊朗@3 分钟前
视频时间基 (time_base) 详解:时间的“刻度单位”
c++
岑梓铭3 分钟前
《考研408数据结构》第七章(6.1~6.3图的概念、存储方式、深/广度遍历)复习笔记
数据结构·笔记·考研·算法·图论·408·ds
脏脏a14 分钟前
【C++ 入门】:引用、内联函数与 C++11 新特性(auto、范围 for、nullptr)全解析
开发语言·c++
AA陈超19 分钟前
虚幻引擎5 GAS开发俯视角RPG游戏 P06-28 构建属性菜单小部件控制器
c++·游戏·ue5·游戏引擎·虚幻
恒者走天下22 分钟前
cpp / c++零基础就业学习一站式学习平台
开发语言·c++·学习
qq_4335545429 分钟前
C++ 单调栈
数据结构·c++·算法
向前阿、31 分钟前
数据结构从基础到实战——排序
c语言·开发语言·数据结构·程序人生·算法
Doro再努力37 分钟前
数据结构04:链表的概念及实现单链表
c语言·数据结构
fpcc41 分钟前
计算机原理—缓存
c++·缓存
2401_841495641 小时前
【语音识别】混合高斯模型
人工智能·python·算法·机器学习·语音识别·gmm·混合高斯模型