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;

        
    }
}
相关推荐
皮皮林5519 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河9 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程12 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅14 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者15 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺15 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart16 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP17 小时前
MyBatis-mybatis入门与增删改查
java
孟陬20 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端