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;
    }
};
相关推荐
感哥8 小时前
C++ 面向对象
c++
沐怡旸10 小时前
【底层机制】std::shared_ptr解决的痛点?是什么?如何实现?如何正确用?
c++·面试
感哥16 小时前
C++ STL 常用算法
c++
saltymilk1 天前
C++ 模板参数推导问题小记(模板类的模板构造函数)
c++·模板元编程
感哥1 天前
C++ lambda 匿名函数
c++
沐怡旸1 天前
【底层机制】std::unique_ptr 解决的痛点?是什么?如何实现?怎么正确使用?
c++·面试
感哥1 天前
C++ 内存管理
c++
博笙困了2 天前
AcWing学习——双指针算法
c++·算法
感哥2 天前
C++ 指针和引用
c++
感哥2 天前
C++ 多态
c++