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; // 返回所有符合条件的组合
    }
};
相关推荐
Leweslyh2 小时前
【实战】设计一颗“永远向阳”且“姿态稳定”的卫星 (例题 4.8)
算法·航天·轨道力学·星际航行·太阳同步轨道
木木木一2 小时前
Rust学习记录--C12 实例:写一个命令行程序
学习·算法·rust
大柏怎么被偷了2 小时前
【C++】哈希桶
数据结构·算法·哈希算法
leaves falling2 小时前
c语言自定义类型深度解析:联合(Union)与枚举(Enum)
c语言·开发语言·算法
期末考复习中,蓝桥杯都没时间学了2 小时前
力扣刷题记录2
算法·leetcode·职场和发展
高洁012 小时前
知识图谱如何结合 RAG实现更精确的知识问答
人工智能·算法·机器学习·数据挖掘·知识图谱
爱喝可乐的老王3 小时前
机器学习监督学习模型----KNN
人工智能·算法·机器学习
闪电麦坤953 小时前
Leecode热题100:环形链表(链表)
数据结构·链表·leecode
WBluuue3 小时前
AtCoder Beginner Contest 441(ABCDEF)
c++·算法