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();
        }
    }
};

後記

呼兒將出換美酒,與爾同銷萬古愁。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章