40.组合总和二

  • 题目详述

 

40. 组合总和 II

给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。

candidates 中的每个数字在每个组合中只能使用一次。

说明:

  • 所有数字(包括目标数)都是正整数。
  • 解集不能包含重复的组合。 

示例 1:

输入: candidates = [10,1,2,7,6,1,5], target = 8,

所求解集为:

[

  [1, 7],

  [1, 2, 5],

  [2, 6],

  [1, 1, 6]

]

示例 2:

输入: candidates = [2,5,2,1,2], target = 5,

所求解集为:

[

  [1,2,2],

  [5]

]

 

二.自我探寻

思路:与39.组合总和(详见博文)基本无异,画树写代码

以[10,1,2,7,6,1,5]为例  排序后 为[1,1,2,5,6,7,10]
树形:
(画了一部分,足以说明与39.组合总和的差异)
代码: class Solution {
     
    public List<List<Integer>> combinationSum2(int[] candidates, int target) {
            int f=candidates.length-1;
            Arrays.sort(candidates);
                   for(int i=0;i<candidates.length;i++)
                   {
                       if(candidates[i]>target)
                       {
                              f=i-1;
                           break;
                       }
                   }
            List<List<Integer>> a=new ArrayList<List<Integer>>();
                   List<Integer> bl=new ArrayList<Integer>();
                painttree(target,-1,f,0, candidates, a, bl);
                return a;
    }
    
    public static void painttree(int target,int t,int f,int sum,int[] sort, List<List<Integer>> a,List<Integer> b)
         {
                for(int j=t+1;j<f+1;j++)
                {
              if(j!=t+1&&sort[j]==sort[j-1])
                        {
                                continue;
                        }
                        sum=sum+sort[j];
                        b.add(sort[j]);
                        if(sum>target) {
                                sum=sum-sort[j];
                                b.remove(b.size()-1);
                                break;
                        }
                        else if(sum==target)
                        {
                                List<Integer> cIntegers=new ArrayList<Integer>();
                            for(int q=0;q<b.size();q++)
                            {
                                cIntegers.add(b.get(q));
                            }
                            a.add(cIntegers);
                                b.remove(b.size()-1);
                                break;
                        }
                        painttree(target, j, f, sum, sort,a, b);
                        sum=sum-sort[j];
                        b.remove(b.size()-1);
                }
                return;
         }
    
}
评价:

 


 

  • 网络学习过程
 

 

  • Python实现

无差异

 
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值