No.77 组合:回溯法

结果

执行用时 :636 ms, 在所有 cpp 提交中击败了15.29%的用户
内存消耗 :167.7 MB, 在所有 cpp 提交中击败了8.43%的用户

时间消耗和空间消耗有点高,不过在使用回溯法的前提下,这是最优解吧。

思路

在这里插入图片描述

代码

class Solution {
public:
    vector<vector<int>> ret;
    vector<vector<int>> combine(int n, int k) {
        backtracking(1,n,k,vector<int>());
        
        return ret;
    }
    
    void backtracking(int start,int n,int k,vector<int> tmp){
        if(tmp.size() == k){
            ret.push_back(tmp);
            return;
        }
        
        for (; start<=n ;start++){
            tmp.push_back(start);
            backtracking(start+1,n,k,tmp);
            tmp.pop_back();
        }
    }
};

后记

呼儿将出换美酒,与尔同销万古愁。

发布了9 篇原创文章 · 获赞 6 · 访问量 1022

猜你喜欢

转载自blog.csdn.net/Acher_zxj/article/details/102756564
今日推荐