首页 > 其他 > 详细

和为定值的m个数

时间:2018-02-20 23:52:34      阅读:310      评论:0      收藏:0      [点我收藏+]

和为定值的m个数

np 问题(时间复杂度o(2**n))

 

 

 

code1:

暴力递归

解决 只有正数的情况

 1 class Solution {
 2     private List<List<Integer>> res = new ArrayList<List<Integer>>();
 3     public List<List<Integer>> fourSum(int[] nums, int target) {
 4         boolean[] a = new boolean[nums.length];
 5         for(int i = 0;i <a.length-1;i++)
 6             a[i] = false;
 7         sum(nums,a,0,0,target);
 8         return res;
 9     }
10     private void sum(int[] nums,boolean[] a,int i,int has,int target){
11         if(i>a.length-1) return;
12         if(has + nums[i] == target){
13             a[i] = true;
14             
15             res.add(add_res(nums,a));
16             a[i] = false;
17         }
18         a[i] = true;
19         sum(nums,a,i+1,has+nums[i],target);
20         a[i] = false;
21         sum(nums,a,i+1,has,target);
22     }
23     private List<Integer> add_res (int[] nums,boolean[] a){
24         List<Integer> res = new ArrayList<Integer>();
25         for(int i = 0;i<a.length;i++)
26             if(a[i])
27                 res.add(nums[i]);
28         return res;
29     }
30 }

 

和为定值的m个数

原文:https://www.cnblogs.com/zle1992/p/8456019.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!