从括号匹配到字符串解码:递归思想的巧妙应用

解题思路

这是一个典型的递归问题。关键在于处理嵌套的括号结构:

  1. 遇到字母:直接加入结果
  2. 遇到数字:累积重复次数
  3. 遇到 [:递归处理括号内的子串
  4. 遇到 ]:当前层递归结束,返回结果

使用全局变量 where 记录当前处理位置,让上层递归知道从哪继续处理。

完整代码实现

java 复制代码
public class Solution {
    // 全局变量,记录当前处理到的位置
    public static int where;
   
    public static String decodeString(String str) {
        where = 0;
        return f(str.toCharArray(), 0);
    }
    
    public static String f(char[] s, int i) {
        StringBuilder path = new StringBuilder();
        int cnt = 0;  // 记录重复次数
        
        // 遍历字符串,直到遇到 ']' 或结束
        while (i < s.length && s[i] != ']') {
            if ((s[i] >= 'a' && s[i] <= 'z') || (s[i] >= 'A' && s[i] <= 'Z')) {
                // 情况1:遇到字母,直接追加
                path.append(s[i++]);
                
            } else if (s[i] >= '0' && s[i] <= '9') {
                // 情况2:遇到数字,累积计算重复次数(可能是多位数)
                cnt = cnt * 10 + s[i++] - '0';
                
            } else {
                // 情况3:遇到 '[',需要递归处理括号内的内容
                // 递归调用 f,从 i+1 位置开始(跳过当前的'[')
                String subResult = f(s, i + 1);
                
                // 将递归结果重复 cnt 次,追加到当前结果
                path.append(get(cnt, subResult));
                
                // 更新 i 到递归结束的位置(跳过对应的']')
                i = where + 1;
                
                // 重置重复次数
                cnt = 0;
            }
        }
        
        // 更新全局位置变量,记录当前处理到哪里
        // 如果遇到']',where指向']';否则指向字符串末尾
        where = i;
        
        return path.toString();
    }
    
    public static String get(int cnt, String str) {
        StringBuilder builder = new StringBuilder();
        for (int i = 0; i < cnt; i++) {
            builder.append(str);
        }
        return builder.toString();
    }
  
}

如果觉得有帮助,欢迎点赞、关注、转发~

相关推荐
xinhuanjieyi12 小时前
Android 画板应用kotlin实现
android·开发语言·kotlin
threelab12 小时前
Three.js 几何图形变换 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
大大杰哥12 小时前
SSeEmitter的基本使用和介绍
java·sse·通信
闪电悠米12 小时前
黑马点评-Redis 消息队列-02_list_pubsub_limits
java·数据库·ide·redis·缓存·list·intellij-idea
无限进步_12 小时前
Linux进程等待——wait、waitpid与僵尸进程
linux·运维·服务器·开发语言
海梨花12 小时前
字节面试高频算法题
java·算法·面试·职场和发展
野生技术架构师12 小时前
Java 23 种设计模式:从踩坑到精通 —— 开篇及系列介绍
java·开发语言·设计模式
故渊at12 小时前
第四板块:Android 输入系统与触控事件 | 第十六篇:按键分发与软键盘(IME)的窗口协同
android·软键盘·输入系统·触控事件·按键分发
Wang ruoxi12 小时前
Pygame 小游戏——数独
开发语言·python·pygame
故渊at12 小时前
第三板块:Android 图形渲染与窗口体系 | 第十四篇:View 绘制体系与 RenderThread 异步渲染
android·图形渲染·ui线程·renderthread·view体系