LeetCode_OJ【40】Combination Sum II
2016-01-12 20:51
363 查看
Given a collection of candidate numbers (C) and a target number (T), find all unique combinations in
C where the candidate numbers sums to T.
Each number in C may only be used once in the combination.
Note:
All numbers (including target) will be positive integers.
Elements in a combination (a1, a2, … ,
ak) must be in non-descending order. (ie, a1 ≤
a2 ≤ … ≤ ak).
The solution set must not contain duplicate combinations.
For example, given candidate set
A solution set is:
下面是本题的JAVA实现。
public class Solution {
public List<List<Integer>> combinationSum2(int[] candidates, int target) {
Arrays.sort(candidates);
List<List<Integer>> res = new ArrayList<List<Integer>>();
List<Integer> tmp = new ArrayList<Integer>();
dfs(res,tmp,candidates,target,0);
return res;
}
public void dfs(List<List<Integer>> res,List<Integer> tmp,int[] candidates, int gap,int index){
if(gap == 0){
List<Integer> list = new ArrayList<Integer>(tmp);
res.add(list);
return;
}
for(int i = index;i < candidates.length; i++){
if(gap < candidates[i])
return;
else{
tmp.add(candidates[i]);
dfs(res,tmp,candidates,gap - candidates[i],i +1);
tmp.remove(tmp.size() -1);
while(i + 1 < candidates.length && candidates[i] == candidates[i +1])
i++;
}
}
}
}
C where the candidate numbers sums to T.
Each number in C may only be used once in the combination.
Note:
All numbers (including target) will be positive integers.
Elements in a combination (a1, a2, … ,
ak) must be in non-descending order. (ie, a1 ≤
a2 ≤ … ≤ ak).
The solution set must not contain duplicate combinations.
For example, given candidate set
10,1,2,7,6,1,5and target
8,
A solution set is:
[1, 7]
[1, 2, 5]
[2, 6]
[1, 1, 6]
本题和39题类似,只不过数组中的数字不能重复选取,而且数组中可能会有重复的数字,导致结果集中会出现重复解,因此如何过滤掉重复解也是本题的关键。
下面是本题的JAVA实现。
public class Solution {
public List<List<Integer>> combinationSum2(int[] candidates, int target) {
Arrays.sort(candidates);
List<List<Integer>> res = new ArrayList<List<Integer>>();
List<Integer> tmp = new ArrayList<Integer>();
dfs(res,tmp,candidates,target,0);
return res;
}
public void dfs(List<List<Integer>> res,List<Integer> tmp,int[] candidates, int gap,int index){
if(gap == 0){
List<Integer> list = new ArrayList<Integer>(tmp);
res.add(list);
return;
}
for(int i = index;i < candidates.length; i++){
if(gap < candidates[i])
return;
else{
tmp.add(candidates[i]);
dfs(res,tmp,candidates,gap - candidates[i],i +1);
tmp.remove(tmp.size() -1);
while(i + 1 < candidates.length && candidates[i] == candidates[i +1])
i++;
}
}
}
}
相关文章推荐
- 有关数据库SQL递归查询在不同数据库中的实现方法
- 解析从源码分析常见的基于Array的数据结构动态扩容机制的详解
- C#中的递归APS和CPS模式详解
- WinForm实现按名称递归查找控件的方法
- 使用SqlServer CTE递归查询处理树、图和层次结构
- C#中的尾递归与Continuation详解
- C#递归实现显示文件夹及所有文件并计算其大小的方法
- php递归创建目录的方法
- javascript数组操作总结和属性、方法介绍
- PHP递归创建多级目录
- mysql_fetch_assoc和mysql_fetch_row的功能加起来就是mysql_fetch_array
- JavaScript Array扩展实现代码
- JavaScript之数组(Array)详解
- Javascript实现Array和String互转换的方法
- C#中Array与ArrayList用法及转换的方法
- Array栈方法和队列方法的特点说明
- Array.prototype.slice 使用扩展
- Javascript递归打印Document层次关系实例分析
- Array, Array Constructor, for in loop, typeof, instanceOf
- 实例详解ECMAScript5中新增的Array方法