[LeetCode] Combinations
2015-07-29 17:15
405 查看
Combinations
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:
解题思路:
这道题的题意是找到1-n的数字中找出k个数的所有组合。可以采用递归回溯法。比较简单。
class Solution {
public:
vector<vector<int>> combine(int n, int k) {
vector<vector<int>> result;
if(n < 0 || k < 0 || n < k){
return result;
}
vector<int> item;
combineHelper(n, k, item, result);
return result;
}
void combineHelper(int n, int k, vector<int> item, vector<vector<int>>& result){
int size = item.size();
if(size>=k){
result.push_back(item);
return;
}
int last = size==0 ? 0 : item[size - 1];
if(n - last + size < k){ //无法达到k的大小了
return;
}
for(int i = last + 1; i <= n; i++){
item.push_back(i);
combineHelper(n, k, item, result);
item.pop_back();
}
}
};
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], ]
解题思路:
这道题的题意是找到1-n的数字中找出k个数的所有组合。可以采用递归回溯法。比较简单。
class Solution {
public:
vector<vector<int>> combine(int n, int k) {
vector<vector<int>> result;
if(n < 0 || k < 0 || n < k){
return result;
}
vector<int> item;
combineHelper(n, k, item, result);
return result;
}
void combineHelper(int n, int k, vector<int> item, vector<vector<int>>& result){
int size = item.size();
if(size>=k){
result.push_back(item);
return;
}
int last = size==0 ? 0 : item[size - 1];
if(n - last + size < k){ //无法达到k的大小了
return;
}
for(int i = last + 1; i <= n; i++){
item.push_back(i);
combineHelper(n, k, item, result);
item.pop_back();
}
}
};
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C++联合体转换成C#结构的实现方法
- C++编写简单的打靶游戏
- C++ 自定义控件的移植问题
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- 使用Lua来扩展C++程序的方法
- C++中调用Lua函数实例
- Lua和C++的通信流程代码实例
- C与C++之间相互调用实例方法讲解
- C++ Custom Control控件向父窗体发送对应的消息
- C++中拷贝构造函数的应用详解