力扣HOT100之栈:394. 字符串解码

这道题又是栈的经典应用,之前拼多多笔试遇到过类似的题目。这回碰到了依旧不会,看完华南溜达虎的视频以后才做出来,感觉这个题目还挺高频的,这次好好记录一下思路。

我们主要使用到一个存储字符串变量的栈stack<string> st,用一个for循环来遍历字符串s中的所有的字符,如果当前字符不是],则持续将当前遍历到的字符添加到st中(由于字符是无法添加到存储字符串的栈中的,因此这里需要将单个字符转换为字符串再压入栈中),如果遇到了],则我们需要进行进一步的处理,首先,题目保证所有的输入都是合法的 ,因此我们可以断定,在遍历到]之前,st中已经存储了与之匹配的[,我们先将[之后加入的字母全都弹出,并用一个字符串temp接收,在接收完毕后,此时栈顶元素一定为[,我们将其弹出,接下来就是数字部分,注意,字符串中的数字可能不止一位,可能会出现11[a12[c]]这种状况,所以我们需要持续地对栈顶元素进行判断,通过调用C++的isdigit函数来判断当前遍历到的字符串是否为数字字符,同样,我们也用一个字符串变量num来接收所有的数字,拼接成正确的形式,然后我们直接调用stoi()num转换成对应的整形变量,在得到了重复次数num和需要重复的字符串temp后,我们直接使用一个while循环将temp重复num次,然后将其再次压入栈中。

注意,以上的操作是针对字符串中出现[]的情形,我们需要将形如x[str]的形式将其转换成strstrstr...的形式,因此我们需要将栈中对应的中括号和数字弹出并正确处理后,将其压入栈中,以便于后续最终结果的拼接。

在遍历完所有字符后,我们将st中的字符串拼接起来即可。

cpp 复制代码
class Solution {
public:
    string decodeString(string s) {
        string result;
        stack<string> st;
        for(char c : s){
            if(c != ']'){   //只要没遇到']'就一直压入栈中
                string temp;
                temp += c;
                st.push(temp);
            }
            else{
                string temp;
                while(st.top() != "["){
                    temp = st.top() + temp;
                    st.pop();
                }
                st.pop();   //弹出[
                string num;
                while(!st.empty() && isdigit(st.top()[0])){  //记录重复次数
                    num = st.top()[0] + num;
                    st.pop();
                } 
                int count = stoi(num);
                string str;
                while(count > 0){
                    str += temp;
                    count--;
                }
                st.push(str);
            }
        }
        while(!st.empty()){
            result = st.top() + result;
            st.pop();
        }
        return result;
    }
};
相关推荐
极创信息17 分钟前
信创产品认证怎么做?信创产品测试认证的主要流程
java·大数据·数据库·金融·软件工程
生成论实验室17 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星31 分钟前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
SamDeepThinking36 分钟前
并发量就算只有2,该上锁还得上呀
java·后端·架构
Sam_Deep_Thinking1 小时前
如何让订单系统和营销系统解耦
java·架构·系统架构
lzhdim1 小时前
SQL 入门 12:SQL 视图:创建、修改与可更新视图
java·大数据·服务器·数据库·sql
科研前沿1 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨1 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月2 小时前
map与unordered_map区别
算法·哈希算法
FQNmxDG4S2 小时前
Maven依赖管理:版本冲突解决与生命周期控制
java·数据库·maven