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; // 返回所有符合条件的组合
    }
};
相关推荐
你撅嘴真丑5 小时前
第九章-数字三角形
算法
uesowys5 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder5 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮5 小时前
AI 视觉连载1:像素
算法
智驱力人工智能5 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥6 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风6 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風6 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT067 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠7 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法