您的位置:首页 > 其它

[LeetCode] Combinations

2016-03-25 22:39 211 查看
题目描述:

Given two integers n and k, return all possible combinations of k numbers out of 1 ... n.

For example,
If n = 4 and k = 2, a solution is:

[
[2,4],
[3,4],
[2,3],
[1,2],
[1,3],
[1,4],
]


解题思路:

class Solution {
public:
vector<vector<int>> combine(int n, int k) {
vector<vector<int>> result;
vector<int> elem;

combine(n, k, 1, result, elem);
return result;
}
private:
void combine(int n, int k, int cur, vector<vector<int>> &result, vector<int> &elem) {
if (elem.size() == k) {
result.push_back(elem);
return;
}

for (int i = cur; i <= n; ++i) {
elem.push_back(i);
combine(n, k, i + 1, result, elem);
elem.pop_back();
}
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: