找出所有可能的 k 个数,使其相加之和为 n,只允许使用数字1-9,并且每一种组合中的数字是唯一的。
示例 1:
输入: k = 3, n = 7
输出:
[[1,2,4]]
示例 2:
输入: k = 3, n = 9
输出:
[[1,2,6], [1,3,5], [2,3,4]]
详见:https://leetcode.com/problems/combination-sum-iii/description/

Java实现:

class Solution {
public List<List<Integer>> combinationSum3(int k, int n) {
List<List<Integer>> res=new ArrayList<List<Integer>>();
List<Integer> out=new ArrayList<Integer>();
helper(k,n,1,out,res);
return res;
}
private void helper(int k,int n,int start,List<Integer> out,List<List<Integer>> res){
if(n<0){
return;
}
if(n==0&&out.size()==k){
res.add(new ArrayList<Integer>(out));
}
for(int i=start;i<=9;++i){
out.add(i);
helper(k,n-i,i+1,out,res);
out.remove(out.size()-1);
}
}
}

C++实现:

class Solution {
public:
vector<vector<int>> combinationSum3(int k, int n) {
vector<vector<int>> res;
vector<int> out;
helper(k,n,1,out,res);
return res;
}
void helper(int k,int n,int start,vector<int> &out,vector<vector<int>> &res)
{
if(n<0)
{
return;
}
if(n==0&&out.size()==k)
{
res.push_back(out);
}
for(int i=start;i<=9;++i)
{
out.push_back(i);
helper(k,n-i,i+1,out,res);
out.pop_back();
}
}
};

最新文章

  1. kzalloc 函数详解(转载)
  2. mimikatz不反弹读取密码
  3. Mac配置
  4. 卷积相关公式的matlab代码
  5. [转]O(n)回文子串算法 Manacher算法
  6. Tomcat输出catalina.out的大小控制
  7. 查看Mac OSX机器上存在的所有Device
  8. js中slice(),splice(),split(),substring(),substr()的使用方法和区别
  9. JavaEE Tutorials (16) - Java消息服务概念
  10. redhat nginx随机启动脚本
  11. shell脚本里获取字符串的最后一个字符
  12. 【Netty源码分析】数据读取过程
  13. Android驱动中的Kconfig文件与Makefile文件
  14. Publisher/Subscriber
  15. Maven中阿里云私服配置
  16. Gvim 和vim 有什么区别
  17. qq截图存放在电脑的哪个文件夹
  18. 监听器&amp;上传下载&amp;I18N
  19. ip本地查询
  20. linux下 php 安装mysql的扩展模块

热门文章

  1. Angular2.x
  2. POJ 题目1204 Word Puzzles(AC自己主动机,多个方向查询)
  3. A Simple Example About Privileged Methods in JavaScript
  4. 2016/4/26 sublime text 2 版本 遇到的问题及解决方法
  5. Apsara Clouder专项技能认证:实现调用API接口 (笔记)
  6. mysql数据库存放路径
  7. ubuntu中查看已安装软件包的方法
  8. socket.io中文文档
  9. 设计模式-(7)桥接(swift版)
  10. XMU C语言程序设计实践(2)