【剑斩OFFER】算法的暴力美学——力扣 394 题:字符串解码

一、题目描述

二、算法原理

思路:使用双栈,一个栈原来存储字符串,另外一个存储整型数字;

1)一开始,把 string 栈先放个空字符串进去,方便后面操作;

2)如果碰到纯字母(非 [ 后面的字母),就让把这些字母提取出来拼接到 string 栈栈顶元素的后面:

3)如果遍历到数字,直接入 int 栈:

4)如果遍历到 ' [ ',就把 [ 后面的字母入 string 栈:

5)如果遍历到 ' ] ',就把双栈的栈顶元素拿出来,进行重复 K 次工作,重复结束之后把这个字符串拼接到栈顶元素的后面(这也是我为什么让 string 一开始放个空串进去的原因):

最终答案:此时 string 的栈顶元素就是最终答案:

三、代码实现

cpp 复制代码
class Solution {
public:
    string decodeString(string s) {
        vector<int> int_stack;
        vector<string> char_stack(1,"");
        
        for(int i = 0; i < s.size();)
        {
            if(s[i] == '[')// "[" 后面跟字母
            {
                i++;
                string str = "";
                while(!isdigit(s[i]) && s[i] != ']' && s[i] != '[')
                {
                    str += s[i];
                    i++;
                }
                char_stack.push_back(str);
            }
            else if(isdigit(s[i]))//纯数字
            {
                int tmp = 0;
                while(isdigit(s[i]))
                {
                    tmp = tmp * 10 + (s[i] - '0');
                    i++;
                }
                int_stack.push_back(tmp);
            }
            else if(s[i] != ']')
            {
                //纯字母
                string str;
                while(i < s.size() && !isdigit(s[i]) && s[i] != ']' && s[i] != '[')
                {
                    str += s[i];
                    i++;
                }
                char_stack.back() += str;
            }
            else //  "]"
            {
                //']'
                //取双栈元素
                int k = int_stack.back();
                string str = char_stack.back();

                //出双栈元素
                int_stack.pop_back();
                char_stack.pop_back();
            
                string ret = "";
                for(int j = 0; j < k; j++) ret += str;

                char_stack.back() += ret;
                i++;
            }
        }

        return char_stack.back();
    }
};
相关推荐
计算机安禾16 小时前
【c++面向对象编程】第32篇:移动语义与右值引用:现代C++性能优化核心
java·c++·性能优化
fish_xk16 小时前
c++11的初见
开发语言·c++·算法
不知名的老吴17 小时前
C++ 中函数对象的形式概述
开发语言·c++
Cthy_hy17 小时前
并查集(Disjoint Set Union):巧判「连通聚类关系」的极简利器
数据结构·算法
Shan120517 小时前
C++中函数对象之重载 operator()
开发语言·c++·算法
djarmy17 小时前
一级函数头地址指针,(*p_func)的函数头的返回值,(*p_func)的函数头的参数列表
c++
阿Y加油吧17 小时前
两道位运算 / 摩尔投票经典题复盘:只出现一次的数字 & 多数元素
数据结构·算法·leetcode
小明同学0117 小时前
C++后端项目:统一大模型接入 SDK(一)
linux·c++·chatgpt
林夕0717 小时前
Qt 6.x 新特性概览:从 Qt 5 到 Qt 6 的升级之路
c++·qt6·跨平台开发
05候补工程师18 小时前
【408狂飙·数据结构】核心考点深度复盘:数组地址计算、特殊矩阵压缩存储与树的五大性质解题直觉
数据结构·笔记·线性代数·考研·算法·矩阵