您好,欢迎来到百家汽车网。
搜索
您的当前位置:首页LeetCode回溯 77. 组合

LeetCode回溯 77. 组合

来源:百家汽车网

给定两个整数 n 和 k,返回范围 [1, n] 中所有可能的 k 个数的组合。

你可以按 任何顺序 返回答案。

示例 1:

输入:n = 4, k = 2
输出:
[
  [2,4],
  [3,4],
  [2,3],
  [1,2],
  [1,3],
  [1,4],
]

示例 2:

输入:n = 1, k = 1
输出:[[1]]

没写出来

剪枝知识点

代码

class Solution {
private:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking(int n, int k, int startIndex) {
        if (path.size() == k) {
            result.push_back(path);
            return;
        }
//到头了就加入     没到头,遍历当前结点往后面的数字
        //       索引
        for (int i = startIndex; i <= n - (k - path.size()) + 1; i++) { 
            path.push_back(i); // 处理节点
            backtracking(n, k, i + 1);

        //也就是 12 2去掉   13 3去掉    
            path.pop_back(); // 回溯,撤销处理的节点

        }


    }
public:

    vector<vector<int>> combine(int n, int k) {
        backtracking(n, k, 1);
        return result;
    }

};

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- baijiahaobaidu.com 版权所有 湘ICP备2023023988号-9

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务