結果
執行用時 :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();
}
}
};
後記
呼兒將出換美酒,與爾同銷萬古愁。