news 2026/1/26 11:50:55

【每日算法】 LeetCode 394. 字符串解码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【每日算法】 LeetCode 394. 字符串解码

对前端开发者而言,学习算法绝非为了“炫技”。它是你从“页面构建者”迈向“复杂系统设计者”的关键阶梯。它将你的编码能力从“实现功能”提升到“设计优雅、高效解决方案”的层面。从现在开始,每天投入一小段时间,结合前端场景去理解和练习,你将会感受到自身技术视野和问题解决能力的质的飞跃。------ 算法:资深前端开发者的进阶引擎

LeetCode 394. 字符串解码

1. 题目描述

给定一个经过编码的字符串,返回它解码后的字符串。

编码规则为:k[encoded_string],表示其中方括号内部的encoded_string正好重复k次。注意k保证为正整数。

你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。

此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数k,例如不会出现像3a2[4]的输入。

示例 1:

输入:s = "3[a]2[bc]" 输出:"aaabcbc"

示例 2:

输入:s = "3[a2[c]]" 输出:"accaccacc"

示例 3:

输入:s = "2[abc]3[cd]ef" 输出:"abcabccdcdcdef"

示例 4:

输入:s = "abc3[cd]xyz" 输出:"abccdcdcdxyz"

2. 问题分析

这道题考察对嵌套结构的处理,非常类似于:

  • HTML/XML 标签的嵌套解析
  • JSON 字符串的解析
  • 前端模板引擎中变量替换的嵌套场景
  • 正则表达式中的分组引用

核心难点在于处理嵌套的括号数字与字符串的对应关系。当遇到嵌套时,需要先解析内层的编码字符串,然后再与外层的数字相乘。

3. 解题思路

3.1 栈解法(最优解)

使用两个栈分别存储数字和字符串:

  1. 遍历输入字符串的每个字符
  2. 遇到数字时,解析完整的数字(可能有多位)
  3. 遇到左括号[时,将当前数字和字符串分别入栈,并重置
  4. 遇到右括号]时,从栈中弹出数字和之前的字符串,构建当前字符串
  5. 遇到字母时,直接追加到当前字符串

时间复杂度:O(n),其中 n 是解码后字符串的长度
空间复杂度:O(n),最坏情况下栈的深度与嵌套深度成正比

3.2 递归解法(DFS)

利用递归天然处理嵌套结构:

  1. 遇到数字时,解析数字和括号内的子字符串
  2. 递归解码子字符串
  3. 将解码结果重复指定次数
  4. 继续处理后续字符

时间复杂度:O(n)
空间复杂度:O(n),递归调用栈的深度

最优解推荐:栈解法。虽然两种方法的时间复杂度相同,但栈解法避免了递归的函数调用开销,且代码结构更清晰直观。

4. 代码实现

4.1 栈解法实现

/** * 栈解法 - 最优解 * @param {string} s * @return {string} */constdecodeString=function(s){letnumStack=[];// 存储数字的栈letstrStack=[];// 存储字符串的栈letnum=0;// 当前数字letresult='';// 当前字符串for(letcharofs){if(!isNaN(char)){// 如果是数字,累加(处理多位数字)num=num*10+parseInt(char);}elseif(char==='['){// 遇到左括号,将当前数字和字符串入栈numStack.push(num);strStack.push(result);// 重置数字和字符串num=0;result='';}elseif(char===']'){// 遇到右括号,出栈并构建字符串constrepeatTimes=numStack.pop();constprevStr=strStack.pop();result=prevStr+result.repeat(repeatTimes);}else{// 普通字母,直接追加result+=char;}}returnresult;};

4.2 递归解法实现

/** * 递归解法 * @param {string} s * @return {string} */constdecodeStringDFS=function(s){letindex=0;constdfs=()=>{letresult='';letnum=0;while(index<s.length){constchar=s[index];if(!isNaN(char)){// 解析数字num=num*10+parseInt(char);index++;}elseif(char==='['){// 遇到左括号,递归处理子字符串index++;// 跳过 '['constinnerStr=dfs();result+=innerStr.repeat(num);num=0;// 重置数字}elseif(char===']'){// 遇到右括号,返回当前结果index++;// 跳过 ']'returnresult;}else{// 普通字符result+=char;index++;}}returnresult;};returndfs();};

5. 各实现思路的复杂度、优缺点对比

方法时间复杂度空间复杂度优点缺点适用场景
栈解法O(n)O(n)1. 逻辑清晰直观
2. 无递归开销
3. 易于调试和跟踪
1. 需要维护两个栈
2. 代码相对较长
通用场景,特别是嵌套层数较深的情况
递归解法O(n)O(n)1. 代码简洁
2. 利用调用栈自然处理嵌套
3. 符合问题本质(DFS)
1. 递归深度受限
2. 可能栈溢出
3. 调试相对困难
嵌套层数可控,代码简洁性优先的场景

6. 总结

6.1 算法核心要点

  1. 栈的运用:处理嵌套结构是栈的典型应用场景
  2. 状态管理:需要同时跟踪数字、字符串和嵌套层级
  3. 遍历策略:一次遍历完成所有解析,保证O(n)时间复杂度

6.2 在前端开发中的实际应用场景

6.2.1 模板引擎解析
// 类似 Vue/React 的模板语法解析consttemplate="Hello {{user.name}}, you have {{notifications.count}} new messages";// 内部实现可能使用类似的栈结构处理嵌套的 {{...}}
6.2.2 CSS 预处理
/* 类似 LESS/Sass 的嵌套规则解析 */.container{width:100%; .item{color:red; &:hover{color:blue;}}}
6.2.3 JSON/XML 解析器

前端常需要解析各种数据格式,理解栈在处理嵌套结构中的应用至关重要。

6.2.4 国际化(i18n)处理
// 多语言字符串中的变量替换和嵌套consti18nString="{count, plural, =0 {No messages} =1 {One message} other {# messages}}";
6.2.5 富文本编辑器

处理嵌套的HTML标签、Markdown语法等都需要类似的解析技术。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/20 12:11:06

CesiumJS体素渲染终极指南:从入门到实战的完整教程

CesiumJS体素渲染终极指南&#xff1a;从入门到实战的完整教程 【免费下载链接】cesium An open-source JavaScript library for world-class 3D globes and maps :earth_americas: 项目地址: https://gitcode.com/GitHub_Trending/ce/cesium CesiumJS体素渲染技术为三维…

作者头像 李华
网站建设 2025/12/27 22:24:17

合规即代码的延伸:国产DevOps平台如何利用平台扩展能力,自动验证信创基础设施的配置合规性

在信创改造浪潮中&#xff0c;基础设施配置合规性验证是保障系统安全、满足监管要求的核心环节。传统合规验证依赖人工检查&#xff0c;存在效率低、覆盖不全、易遗漏、难追溯等问题&#xff0c;难以适配信创环境下 “国产化软硬件适配、安全基线达标、政策动态更新” 的复杂需…

作者头像 李华
网站建设 2026/1/6 10:18:14

Photon框架深度剖析:构建高效Electron应用的全新视角

Photon框架深度剖析&#xff1a;构建高效Electron应用的全新视角 【免费下载链接】photon The fastest way to build beautiful Electron apps using simple HTML and CSS 项目地址: https://gitcode.com/gh_mirrors/pho/photon 在Electron应用开发领域&#xff0c;选择…

作者头像 李华
网站建设 2025/12/28 6:08:36

本科生论文查询排名:7大平台全方位测评

本科生论文查询排名&#xff1a;7大平台全方位测评 7大论文查询平台核心功能对比 排名 平台名称 核心功能 效率评分 适用场景 1 知网 权威文献检索 ★★★★★ 文献综述、选题参考 2 aicheck 选题生成文献综述辅助 ★★★★☆ 开题阶段快速搭建框架 3 万方 中…

作者头像 李华
网站建设 2025/12/28 6:08:33

fasthttp 的 server.Shutdown() 究竟能不能实现 graceful shutdown

文将通过源码阅读的方式&#xff0c;推导 fasthttp 实现 graceful shutdown 的细节。1. 业务代码中的 graceful shutdown 实现方法func main(){// ...// 容器退出前会先发送 SIGTERM 信号sigs : make(chan os.Signal, 1)signal.Notify(sigs, syscall.SIGHUP,syscall.SIGINT,sys…

作者头像 李华
网站建设 2026/1/22 7:47:16

揭秘量子计算开发痛点:VSCode如何重塑量子模拟器协作生态

第一章&#xff1a;量子模拟器扩展的 VSCode 兼容性随着量子计算技术的发展&#xff0c;开发者对本地开发环境的要求日益提高。Visual Studio Code 作为主流的代码编辑器&#xff0c;凭借其强大的扩展生态&#xff0c;已成为量子程序开发的重要平台。通过集成量子模拟器扩展&am…

作者头像 李华