🚀 力扣热题 394:字符串解码(详细解析)(Go语言版)

简介: 文章提供了两种解法:栈结构和递归解法。栈解法通过维护数字栈与字符串栈,依次处理 `[` 和 `]`,构造解码结果;递归解法则利用函数调用逐层解析嵌套结构。两者时间复杂度均为 $O(n)$,空间复杂度也为 $O(n)$。栈解法直观易懂,适合初学者;递归解法优雅简洁,适合处理深度嵌套规则。掌握这两种方法,可灵活应对类似问题,提升解题能力。

🚀 力扣热题 394:字符串解码(详细解析)

📌 题目描述

力扣 394. 字符串解码

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

编码规则为:k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。你可以认为 k 总是一个正数。

注意:输入字符串中只包含数字、英文字母、方括号 [] 和不会嵌套的数字。

🌟 示例 1:

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

🌟 示例 2:

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

🌟 示例 3:

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

💡 解题思路

✅ 栈结构(Stack)解法

这是一个经典的 栈应用题,核心思路是:

  • 遇到 [ :将当前数字(重复次数)和字符串入栈。
  • 遇到 ] :弹出栈顶元素,构造新字符串。
  • 遇到字母:追加到当前字符串中。

我们维护两个栈:

  1. 数字栈:存储重复次数。
  2. 字符串栈:存储括号外的字符串。

💻 Go 实现代码

✅ 方法一:使用两个栈

func decodeString(s string) string {
   
    numStack := []int{
   }
    strStack := []string{
   }
    currStr := ""
    num := 0

    for _, ch := range s {
   
        if ch >= '0' && ch <= '9' {
   
            num = num*10 + int(ch-'0')
        } else if ch == '[' {
   
            numStack = append(numStack, num)
            strStack = append(strStack, currStr)
            num = 0
            currStr = ""
        } else if ch == ']' {
   
            repeat := numStack[len(numStack)-1]
            numStack = numStack[:len(numStack)-1]

            prevStr := strStack[len(strStack)-1]
            strStack = strStack[:len(strStack)-1]

            temp := ""
            for i := 0; i < repeat; i++ {
   
                temp += currStr
            }
            currStr = prevStr + temp
        } else {
   
            currStr += string(ch)
        }
    }
    return currStr
}

✅ 方法二:递归解法

另一种常见的解法是使用递归。递归的思想是将当前字符串按照解码规则拆解,每次遇到 ] 就进行一层解码,然后返回结果。我们通过递归调用来处理字符串中的每一部分。

递归思路:

  • 遇到数字时,开始收集数字,表示重复次数。
  • 遇到 [ 时,递归解析其中的字符串,并将解码后的部分乘以数字。
  • 遇到 ] 时,返回当前的结果并将结果拼接到之前的解码字符串中。

步骤:

  • 遇到字母,直接拼接到当前的解码字符串。
  • 遇到数字,记录并构建重复次数。
  • 遇到 [ 时,开始递归调用处理括号内的字符串。
  • 遇到 ] 时,返回当前解析的结果并继续处理外部字符串。

    ✅ 方法二:递归解法

    ```go
    func decodeString(s string) string {
    index := 0
    return decodeHelper(s, &index)
    }

func decodeHelper(s string, index int) string {
res := ""
for
index < len(s) {
ch := s[index]
if ch >= '0' && ch <= '9' {
num := 0
for
index < len(s) && s[index] >= '0' && s[index] <= '9' {
num = num10 + int(s[index]-'0')
index++
}
index++ // skip '['
str := decodeHelper(s, index)
index++ // skip ']'
for i := 0; i < num; i++ {
res += str
}
} else if ch == ']' {
return res
} else {
res += string(ch)
index++
}
}
return res
}
```

【比较分析】

方法 特点 处理步骤 处理嵌套性 应用场景
栈解法 简洁直观,便于理解 递渐构造字符串 支持嵌套 适合初学者
递归解法 逻辑清晰,方便处理嵌套结构 循环解析,函数循环构造结果 更适合深度嵌套规则 高级结构处理

⏳ 复杂度分析

操作 时间复杂度 空间复杂度
栈/递归 $O(n)$ $O(n)$
  • n 是字符串长度,遍历一遍,各步操作均为常数时间
  • 空间用于栈或递归调用的结果缓存

🌟 总结

  • 栈和递归都是解决本题的有效途径
  • 栈解法更加简单直观,适合初学和面试习题
  • 递归解法适合处理庞复的嵌套规则,优雅简洁

💡 成熟掌握两种思路,能使你展现多样化的解题技巧。

目录
相关文章
|
10月前
|
人工智能 自然语言处理 算法
Go语言统计字符串中每个字符出现的次数 — 简易频率分析器
本案例实现一个字符统计程序,支持中文、英文及数字,可统计用户输入文本中各字符的出现次数,并以整洁格式输出。内容涵盖应用场景、知识点讲解、代码实现与拓展练习,适合学习文本分析及Go语言基础编程。
|
9月前
|
数据采集 数据挖掘 测试技术
Go与Python爬虫实战对比:从开发效率到性能瓶颈的深度解析
本文对比了Python与Go在爬虫开发中的特点。Python凭借Scrapy等框架在开发效率和易用性上占优,适合快速开发与中小型项目;而Go凭借高并发和高性能优势,适用于大规模、长期运行的爬虫服务。文章通过代码示例和性能测试,分析了两者在并发能力、错误处理、部署维护等方面的差异,并探讨了未来融合发展的趋势。
939 0
|
7月前
|
Cloud Native 安全 Java
Go语言深度解析:从入门到精通的完整指南
🌟蒋星熠Jaxonic,Go语言探索者。深耕云计算、微服务与并发编程,以代码为笔,在二进制星河中书写极客诗篇。分享Go核心原理、性能优化与实战架构,助力开发者掌握云原生时代利器。#Go语言 #并发编程 #性能优化
632 43
Go语言深度解析:从入门到精通的完整指南
|
8月前
|
Cloud Native 安全 Java
Go语言深度解析:从入门到精通的完整指南
🌟 蒋星熠Jaxonic,执着的星际旅人,用Go语言编写代码诗篇。🚀 Go语言以简洁、高效、并发为核心,助力云计算与微服务革新。📚 本文详解Go语法、并发模型、性能优化与实战案例,助你掌握现代编程精髓。🌌 从goroutine到channel,从内存优化到高并发架构,全面解析Go的强大力量。🔧 实战构建高性能Web服务,展现Go在云原生时代的无限可能。✨ 附技术对比、最佳实践与生态全景,带你踏上Go语言的星辰征途。#Go语言 #并发编程 #云原生 #性能优化
|
11月前
|
存储 设计模式 安全
Go 语言单例模式全解析:从青铜到王者段位的实现方案
单例模式确保一个类只有一个实例,并提供全局访问点,适用于日志、配置管理、数据库连接池等场景。在 Go 中,常用实现方式包括懒汉模式、饿汉模式、双重检查锁定,最佳实践是使用 `sync.Once`,它并发安全、简洁高效。本文详解各种实现方式的优缺点,并提供代码示例与最佳应用建议。
371 5
|
9月前
|
缓存 监控 安全
告别缓存击穿!Go 语言中的防并发神器:singleflight 包深度解析
在高并发场景中,多个请求同时访问同一资源易导致缓存击穿、数据库压力过大。Go 语言提供的 `singleflight` 包可将相同 key 的请求合并,仅执行一次实际操作,其余请求共享结果,有效降低系统负载。本文详解其原理、实现及典型应用场景,并附示例代码,助你掌握高并发优化技巧。
683 0
|
9月前
|
数据采集 JSON Go
Go语言实战案例:实现HTTP客户端请求并解析响应
本文是 Go 网络与并发实战系列的第 2 篇,详细介绍如何使用 Go 构建 HTTP 客户端,涵盖请求发送、响应解析、错误处理、Header 与 Body 提取等流程,并通过实战代码演示如何并发请求多个 URL,适合希望掌握 Go 网络编程基础的开发者。
|
12月前
|
存储 算法 Go
【LeetCode 热题100】17:电话号码的字母组合(详细解析)(Go语言版)
LeetCode 17题解题思路采用回溯算法,通过递归构建所有可能的组合。关键点包括:每位数字对应多个字母,依次尝试;递归构建下一个字符;递归出口为组合长度等于输入数字长度。Go语言实现中,使用map存储数字到字母的映射,通过回溯函数递归生成组合。时间复杂度为O(3^n * 4^m),空间复杂度为O(n)。类似题目包括括号生成、组合、全排列等。掌握回溯法的核心思想,能够解决多种排列组合问题。
497 11
|
12月前
|
Go
【LeetCode 热题100】155:最小栈(详细解析)(Go语言版)
本文详细解析了力扣热题155:最小栈的解题思路与实现方法。题目要求设计一个支持 push、核心思路是使用辅助栈法,通过两个栈(主栈和辅助栈)来维护当前栈中的最小值。具体操作包括:push 时同步更新辅助栈,pop 时检查是否需要弹出辅助栈的栈顶,getMin 时直接返回辅助栈的栈顶。文章还提供了 Go 语言的实现代码,并对复杂度进行了分析。此外,还介绍了单栈 + 差值记录法的进阶思路,并总结了常见易错点,如 pop 操作时忘记同步弹出辅助栈等。
416 6
|
12月前
|
Go 索引
【LeetCode 热题100】739:每日温度(详细解析)(Go语言版)
这篇文章详细解析了 LeetCode 第 739 题“每日温度”,探讨了如何通过单调栈高效解决问题。题目要求根据每日温度数组,计算出等待更高温度的天数。文中推荐使用单调递减栈,时间复杂度为 O(n),优于暴力解法的 O(n²)。通过实例模拟和代码实现(如 Go 语言版本),清晰展示了栈的操作逻辑。此外,还提供了思维拓展及相关题目推荐,帮助深入理解单调栈的应用场景。
457 6

热门文章

最新文章

推荐镜像

更多
  • DNS