leetcode216--组合总和III

1. 题意

找出所有相加之和为 n 的 k 个数的组合,且满足下列条件:

  • 只使用数字1到9
  • 每个数字 最多使用一次

返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

2. 题解

2.1 回溯
cpp 复制代码
class Solution {
public:
    void search(int begin, vector<vector<int>> &ans,vector<int> &seq, int sum, 
    int n,int k) {
        
        if ( sum == n && seq.size() == k) {
            ans.emplace_back( seq );
            return;
        }
        if ( sum > n || seq.size() > k)
            return;


        for (int i = begin; i < 10; i++) {
            seq.emplace_back(i);
            search( i + 1,ans, seq, sum + i, n, k);
            seq.pop_back();
        }

    }

    vector<vector<int>> combinationSum3(int k, int n) {
        int mx = (9 + (10 - k)) * k / 2;

        vector<vector<int>> ans;
        if ( mx < n)
            return ans;

        vector<int> seq;
        search(1, ans, seq, 0, n, k);
        
        return ans;
    }
};
2.2 二进制枚举

直接枚举每一种可能,判断是否满足即可。

cpp 复制代码
class Solution {
public:
    bool check(int v, int n, int k) {

        int one_cnt  = 0;
        int sum = 0;
        for (int i = 0;i < 9; ++i) {
            if (v & (1 << i))
                one_cnt++, sum += i + 1;
        }

        return one_cnt == k && sum == n;
    }


    vector<vector<int>> combinationSum3(int k, int n) {
        
        vector<vector<int>> ans;
        vector<int> seq;
        for (int i = 1; i < (1 << 9); ++i) {

            if ( check(i, n, k) ) {
                seq.clear();
                for (int j = 0;j < 9; ++j) {
                    if ( i & (1 << j))
                        seq.emplace_back( j + 1);
                }
                ans.emplace_back(seq);
            }
        }

        
        return ans;
    }
};
相关推荐
hansang_IR1 分钟前
【题解】类欧几里得算法
c++·数学·算法·类欧几里得
陈天伟教授1 分钟前
人工智能应用- 人工智能交叉:06.解析蛋白质宇宙
人工智能·神经网络·算法·机器学习·推荐算法
We་ct5 分钟前
LeetCode 114. 二叉树展开为链表:详细解题思路与 TS 实现
前端·数据结构·算法·leetcode·链表·typescript
像素猎人5 分钟前
范围for语法(除for循环/while循环/do...while循环的第四种循环)
数据结构·算法
10 分钟前
2.20进制转化,表达式求值,删除字符
开发语言·c++·算法
追随者永远是胜利者13 分钟前
(LeetCode-Hot100)461. 汉明距离
java·算法·leetcode·职场和发展·go
努力学算法的蒟蒻16 分钟前
day90(2.19)——leetcode面试经典150
算法·leetcode·面试
啊阿狸不会拉杆22 分钟前
《计算机视觉:模型、学习和推理》第 5 章-正态分布
人工智能·python·学习·算法·机器学习·计算机视觉·正态分布
样例过了就是过了28 分钟前
LeetCode热题100 缺失的第一个正数
数据结构·算法·leetcode
样例过了就是过了31 分钟前
LeetCode热题100 除了自身以外数组的乘积
数据结构·算法·leetcode