【LeetCode热题100(69/100)】字符串解码

题目地址: 链接

思路: 栈。

  1. 遇到非]字符,压入栈
  2. 遇到]字符,将[ ]中的字符str拿出来,[前面的数字num拿出来,根据重复numstr字符,并将其压入栈。
ts 复制代码
function decodeString(s: string): string {
    let stk = [];
    for(let str of s) {
        if(str !== ']') stk.push(str);
        else {
            let str = ''
            while(stk[stk.length - 1] !== '[') {
                str = stk.pop() + str;
            }
            stk.pop(); // 弹出 [
            
            let numStr = '';
            while('0' <= stk[stk.length - 1] && stk[stk.length - 1] <= '9') {
                numStr = stk.pop() + numStr;
            }
            let substr = '';
            for(let i = 0; i < parseInt(numStr); i ++) {
                substr += str;
            }
            stk.push(substr);
        }
    }
    return stk.join('');
};
相关推荐
清静诗意2 小时前
Ubuntu Redis 安装与配置指南
linux·redis·ubuntu
普通网友2 小时前
内存对齐与缓存友好设计
开发语言·c++·算法
小白程序员成长日记2 小时前
2025.11.18 力扣每日一题
算法·leetcode·职场和发展
Cathyqiii2 小时前
传统扩散模型 VS Diffusion-TS
人工智能·算法
海边夕阳20062 小时前
【每天一个AI小知识】:什么是逻辑回归?
人工智能·算法·逻辑回归
普通网友2 小时前
C++编译期数据结构
开发语言·c++·算法
Gorgous—l2 小时前
数据结构算法学习:LeetCode热题100-图论篇(岛屿数量、腐烂的橘子、课程表、实现 Trie (前缀树))
数据结构·学习·算法
HalvmånEver2 小时前
Linux:基础开发工具(六)
linux·运维·服务器
百***48072 小时前
Linux下MySQL的简单使用
linux·mysql·adb