2026年--Lc330-394. 字符串解码(栈)--java版

1.题目


2.思路

补充1:

用双栈,一个是数字栈,一个是符号栈。用来分别存储数字和符号。创建数字的临时变量、字符串的临时变量,用来保存现场。

遍历传入的参数,如果遇到的字符是数字,且数字是多位用num乘法10+尾数-'0';如果是左括号,把之前遇到的数字加入到数字栈,字符加入到字符栈,同时充值数字临时变量和字符临时变量,重新寻找。如果遇到右括号,将栈顶的数字弹出来,查看要循环几次。同时把字符栈的栈顶元素弹出来。将当前的字符串进行追加拼接,返回合并的结果。如果遇到的是普通字符,用字符临时变量和当前字符进行拼接。

补充2:

curStr 始终表示:"当前这一层(当前所处括号层级)正在构建的字符串结果"。

在最外层(还没进任何括号)时:curStr 是最外层已经拼好的字符串。

进入一层 [ 后:我们把外层的 curStr 入栈保存,然后把 curStr="",开始在新层里拼括号内部的内容。

在括号内部遇到字母:curStr += 字母,它就慢慢变成括号内部的字符串。

遇到 ]:说明括号内部拼完了,此时 curStr 就是 这一层括号内的结果,要拿它去重复 times 次,并接回上一层前缀。

所以:curStr 是"当前层"的工作区,会随着层级变化而变化。

strSt.pop() 给你的是上一层括号外的前缀

curStr 是这一层括号内已经解码好的字符串

sb.append(curStr) 是把括号内的内容重复拼接回前缀里

栈里存的是"外层的 curStr(前缀)",不是当前括号内部的内容

例子:

3.代码实现

java 复制代码
class Solution {
    public String decodeString(String s) {
        Stack<Integer> numSt=new Stack<>();
        Stack<String> strSt=new Stack<>();
        //数字的临时变量
        int num=0;
        //字符串的临时变量
        String curStr="";
        for(int i=0;i<s.length();i++)
        {
            //获取当前字符
            char curCharacter=s.charAt(i);
            //如果是遇到的字符是数字
            if(Character.isDigit(curCharacter))
            {
              num=num*10+curCharacter-'0';
            }else if(curCharacter=='[')
            {
                //4.如果是左括号,把当前的数字和字符入栈,同时重置当前数字和当前字符串
                numSt.push(num);
                strSt.push(curStr);
                num=0;
                curStr="";
            }else if(curCharacter==']')
            {
                 //5.如果是右括号,就进行解码。得到当前字符串就是要重复的次数,也就是[]前的数字
                 int times=numSt.pop();
                  //6.创建栈顶元素的String容器
                  StringBuilder sb=new StringBuilder(strSt.pop());
                  for(int k=0;k<times;k++)
                  {
                    sb.append(curStr);
                  }
                  // 关键:合并结果回到 curStr
                  curStr =sb.toString();
            }else{
                //7.如果是字母就更新字母栈为当前字母,也就是直接加入到当前字符串中
//                 把当前读到的普通字母追加到当前正在构建的字符串 curStr 后面。

// 比如当前 curStr="ab",读到 curCharacter='c':

// 变成 "ab" + 'c' → "abc"
                 curStr=curStr+curCharacter;
            }


        }
        return curStr;

        
    }
}
相关推荐
蓝程序1 天前
Spring AI学习 程序接入大模型
java·人工智能·spring
nice_lcj5201 天前
数据结构之树与二叉树:重点梳理与拓展
java·数据结构
毕设源码-钟学长1 天前
【开题答辩全过程】以 助学贷款管理系统为例,包含答辩的问题和答案
java
2501_941800881 天前
从微服务限流到系统稳定性的互联网工程语法实践与多语言探索
开发语言·python
亓才孓1 天前
任意大小的整数和任意精度的小数的API方法
java
清水白石0081 天前
《深度剖析 Pandas GroupBy:底层实现机制与性能瓶颈全景解析》
开发语言·python·numpy
2501_941875281 天前
从资源隔离到多租户安全的互联网工程语法构建与多语言实践分享
java·开发语言
hui函数1 天前
python全栈入门到实战【基础篇 03】入门实操:第一个Python程序 + PyCharm使用 + 输入输出全解析
开发语言·python·pycharm
EveryPossible1 天前
地图展示练习-C
开发语言