【LeetCode 热题100】回溯:括号生成 & 组合总和(力扣22 / 39 )(Go语言版)

🔥 回溯专题:括号生成 & 组合总和(LeetCode 22 & 39)

LeetCode 回溯经典题:

  • 22. 括号生成
  • 39. 组合总和

这两道题都考察了回溯算法的剪枝与路径构造能力


🧩 一、22. 括号生成

📌 题目描述

给你一个整数 n,请你生成所有由 n 对括号组成的有效括号组合

🔍 示例

text 复制代码
输入:n = 3
输出:["((()))","(()())","(())()","()(())","()()()"]

💡 解题思路

这是一道典型的回溯搜索问题,我们通过维护左右括号的使用数量来构造合法的组合。

✅ 回溯核心逻辑:
  • 初始状态:left = 0, right = 0

  • 分支选择:

    • 如果 left < n:可以添加 '('
    • 如果 right < left:可以添加 ')'
  • 当左右括号都用完(即 left == right == n)时,将当前路径加入结果集。

📦 Go 实现
go 复制代码
func generateParenthesis(n int) []string {
    var res []string
    var backtrack func(path string, left, right int)

    backtrack = func(path string, left, right int) {
        if len(path) == 2*n {
            res = append(res, path)
            return
        }
        if left < n {
            backtrack(path+"(", left+1, right)
        }
        if right < left {
            backtrack(path+")", left, right+1)
        }
    }

    backtrack("", 0, 0)
    return res
}

⚠️ 注意事项

  • 不允许 right > left,否则括号会不合法;
  • 剪枝条件写清楚,否则可能生成不合法组合或死递归。

🎯 二、39. 组合总和

📌 题目描述

给你一个无重复正整数数组 candidates ,和一个目标整数 target,找出所有可以使数字和为 target 的组合。 每个数可以重复使用无限次

🔍 示例

text 复制代码
输入:candidates = [2,3,6,7], target = 7
输出:[[2,2,3],[7]]

💡 解题思路

这是标准的回溯 + 剪枝问题 ,本质是一个组合问题

✅ 回溯核心逻辑:
  • 状态参数:当前组合 path,当前总和 sum,起始索引 start

  • 分支选择:遍历 candidates[i],每次可选择当前元素或后面的元素(允许重复选择

  • 剪枝策略:

    • sum > target,剪枝;
    • sum == target,添加结果;
    • sum < target,继续递归。
📦 Go 实现
go 复制代码
func combinationSum(candidates []int, target int) [][]int {
    var res [][]int
    var path []int

    var dfs func(start, sum int)
    dfs = func(start, sum int) {
        if sum == target {
            temp := make([]int, len(path))
            copy(temp, path)
            res = append(res, temp)
            return
        }
        if sum > target {
            return
        }

        for i := start; i < len(candidates); i++ {
            path = append(path, candidates[i])
            dfs(i, sum + candidates[i]) // 可重复使用同一个数
            path = path[:len(path)-1]   // 回溯
        }
    }

    dfs(0, 0)
    return res
}

⚠️ 注意事项

  • 每层递归都从当前索引 start 开始,确保可以重复选择元素;
  • 注意剪枝时不要提前跳过合法路径;
  • 每次递归完后必须回溯清除最后一个元素

🧠 总结与对比

特性 括号生成(22) 组合总和(39)
技巧类型 回溯 + 状态剪枝 回溯 + 剪枝 + 组合
路径构建逻辑 括号平衡 + 左右限制 数组和满足目标
剪枝条件 right <= left,括号合法 sum <= target
是否可重复选择
输出顺序 所有合法括号 所有合法组合

这两道题分别属于回溯算法中常见的「字符串构造类问题 」与「数字组合类问题」。


📘 结语

  • 回溯是一种通过「递归试探 + 状态恢复」来寻找所有可行解的方法;
  • 掌握回溯的关键在于明确:路径、选择列表、结束条件与剪枝逻辑

相关推荐
多多*3 分钟前
牛客周赛 Round 114 Java题解
算法
他们叫我一代大侠18 分钟前
Leetcode :模拟足球赛小组各种比分的出线状况
算法·leetcode·职场和发展
Nebula_g21 分钟前
C语言应用实例:硕鼠游戏,田忌赛马,搬桌子,活动选择(贪心算法)
c语言·开发语言·学习·算法·游戏·贪心算法·初学者
AI科技星1 小时前
张祥前统一场论动量公式P=m(C-V)误解解答
开发语言·数据结构·人工智能·经验分享·python·线性代数·算法
海琴烟Sunshine1 小时前
leetcode 345. 反转字符串中的元音字母 python
python·算法·leetcode
geobuilding1 小时前
将大规模shp白模贴图转3dtiles倾斜摄影,并可单体化拾取建筑
算法·3d·智慧城市·数据可视化·贴图
jghhh012 小时前
基于高斯伪谱法的弹道优化方法及轨迹仿真计算
算法
mm-q29152227293 小时前
【天野学院5期】 第5期易语言半内存辅助培训班,主讲游戏——手游:仙剑奇侠传4,端游:神魔大陆2
人工智能·算法·游戏
MoRanzhi12033 小时前
Python 实现:从数学模型到完整控制台版《2048》游戏
数据结构·python·算法·游戏·数学建模·矩阵·2048
2401_841495644 小时前
【数据结构】基于BF算法的树种病毒检测
java·数据结构·c++·python·算法·字符串·模式匹配