C++ | Leetcode C++题解之第216题组合总和III

题目:

题解:

cpp 复制代码
class Solution {
private:
    vector<vector<int>> res;
    void backtracking(int k, int n, vector<int> ans){
        if(k == 0 || n <= 0){
            if(k == 0 && n == 0){
                res.emplace_back(ans);
            }
            return;
        }
        int start = (ans.size() == 0 ? 0 : ans.back()) + 1;
        for(int i = start; i < 10; i++){
            if(n - i < 0)break;  // 加上元素i已经超过n,更大的i也就无须枚举了
            ans.emplace_back(i);
            backtracking(k - 1, n - i, ans);
            ans.pop_back();
        }
    }
public:
    vector<vector<int>> combinationSum3(int k, int n) {
        if(n < (k + 1) * k / 2 || n > (19- k) * k / 2)return res;
        vector<int> ans;
        backtracking(k, n, ans);
        return res;
    }
};
相关推荐
Jeremy爱编码2 分钟前
leetcode课程表
算法·leetcode·职场和发展
努力学算法的蒟蒻21 分钟前
day46(12.27)——leetcode面试经典150
算法·leetcode·面试
CC.GG2 小时前
【C++】哈希表的实现
java·c++·散列表
元亓亓亓2 小时前
LeetCode热题100--152. 乘积最大子数组--中等
算法·leetcode·职场和发展
bkspiderx2 小时前
C++变量生命周期:从创建到销毁的完整旅程
c++·生命周期·作用域·变量生命周期
梭七y3 小时前
【力扣hot100题】(103)移动零
数据结构·算法·leetcode
T0uken3 小时前
现代 C++ 项目的 CMake 工程组织
c++
Jeremy爱编码4 小时前
leetcode热题腐烂的橘子
算法·leetcode·职场和发展
H CHY4 小时前
C++代码
c语言·开发语言·数据结构·c++·算法·青少年编程
alphaTao4 小时前
LeetCode 每日一题 2025/12/22-2025/12/28
算法·leetcode