leetcode回溯算法(216.组合总和Ⅲ)

cpp 复制代码
class Solution {
public:
    vector<int> path; // 存储当前组合的临时路径
    vector<vector<int>> result; // 存储所有符合条件的组合结果
    
    // 回溯函数
    // 参数说明:
    // k - 需要的数字个数
    // n - 目标和
    // start - 当前搜索起始数字(1-9)
    // count - 当前路径中数字的总和
    void backtracking(int k, int n, int start, int count) {
        // 终止条件:路径长度达到k
        if (path.size() == k) {
            // 如果当前总和等于目标值n,将路径加入结果集
            if (count == n) {
                result.push_back(path);
            }
            return; // 结束当前分支
        }
        
        // 遍历可能的数字选择(1-9)
        for (int i = start; i <= 9; i++) {
            path.push_back(i); // 选择当前数字i加入路径
            count += i; // 更新当前总和
            
            // 递归进入下一层,从i+1开始(避免重复使用数字)
            backtracking(k, n, i + 1, count);
            
            // 回溯:撤销选择
            path.pop_back(); // 从路径中移除当前数字
            count -= i; // 从总和中减去当前数字
        }
    }
    
    vector<vector<int>> combinationSum3(int k, int n) {
        // 剪枝优化:检查最小可能和是否已超过n
        int j = 1; // 从1开始
        int sum = 0; // 计算最小可能和
        for (int i = 0; i < k; i++) {
            sum += j; // 累加连续最小数字
            j++; // 数字递增
            if (sum > n) return result; // 如果最小可能和已大于n,直接返回空结果
        }
        
        // 开始回溯搜索
        backtracking(k, n, 1, 0);
        
        return result; // 返回所有符合条件的组合
    }
};
相关推荐
我是咸鱼不闲呀12 分钟前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
qq74223498416 分钟前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析
人工智能·算法·工业·aps·排程
数智工坊21 分钟前
【数据结构-树与二叉树】4.5 线索二叉树
数据结构
A尘埃42 分钟前
超市购物篮关联分析与货架优化(Apriori算法)
算法
.小墨迹1 小时前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
数智工坊1 小时前
【数据结构-树与二叉树】4.3 二叉树的存储结构
数据结构
独好紫罗兰1 小时前
对python的再认识-基于数据结构进行-a004-列表-实用事务
开发语言·数据结构·python
不穿格子的程序员1 小时前
从零开始刷算法——贪心篇1:跳跃游戏1 + 跳跃游戏2
算法·游戏·贪心
大江东去浪淘尽千古风流人物1 小时前
【SLAM新范式】几何主导=》几何+学习+语义+高效表示的融合
深度学习·算法·slam
铉铉这波能秀1 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list