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;
    }
};
相关推荐
止观止7 分钟前
C++20 Concepts:让模板错误信息不再“天书”
c++·c++20·编程技巧·模板编程·concepts
FL162386312916 分钟前
ONNX RuntimeC++ 静态库下载安装和使用教程
开发语言·c++
Mz122119 分钟前
day05 移动零、盛水最多的容器、三数之和
数据结构·算法·leetcode
誰能久伴不乏24 分钟前
Linux文件套接字AF_UNIX
linux·服务器·c语言·c++·unix
念越30 分钟前
判断两棵二叉树是否相同(力扣)
算法·leetcode·入门
豆豆plus44 分钟前
C++实现文件操作类
开发语言·c++
墨雪不会编程1 小时前
C++基础语法篇五 ——类和对象
java·前端·c++
sin_hielo2 小时前
leetcode 3512
数据结构·算法·leetcode