[leetcode] Combination Sum III
2015-06-03 15:49
218 查看
简单题,和前面两个类似。代码如下:
class Solution {
public:
vector<vector<int>> combinationSum3(int k, int n) {
vector<vector<int> > result;
vector<int> num;
dfs(k, n, result, num, 1);
return result;
}
private:
void dfs(int k, int n, vector<vector<int> > &result, vector<int> &num, int cur){
if(n == 0 && k == 0){
result.push_back(num);
return;
}
if(k == 0 || cur > 9 || n < cur)
return;
num.push_back(cur);
dfs(k - 1, n - cur, result, num, cur + 1);
num.pop_back();
dfs(k, n, result, num, cur + 1);
}
};
class Solution {
public:
vector<vector<int>> combinationSum3(int k, int n) {
vector<vector<int> > result;
vector<int> num;
dfs(k, n, result, num, 1);
return result;
}
private:
void dfs(int k, int n, vector<vector<int> > &result, vector<int> &num, int cur){
if(n == 0 && k == 0){
result.push_back(num);
return;
}
if(k == 0 || cur > 9 || n < cur)
return;
num.push_back(cur);
dfs(k - 1, n - cur, result, num, cur + 1);
num.pop_back();
dfs(k, n, result, num, cur + 1);
}
};
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C#数据结构与算法揭秘二
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C++联合体转换成C#结构的实现方法
- C#实现的算24点游戏算法实例分析
- C++编写简单的打靶游戏
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- C++中调用Lua函数实例