描述
给定一个含不同整数的集合,返回其所有的子集。
子集中的元素排列必须是非降序的,解集必须不包含重复的子集。
样例
样例 1:
输入:[0]
输出:
[
[],
[0]
]
样例 2:
输入:[1,2,3]
输出:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
第一回因为没有加上排序所以造成结果错误。
第二次提交使用了最简单的冒泡排序,答案正确
代码如下:
import java.util.ArrayList;
import java.util.List;
public class Exp17 {
public static void diGui(int start, List<Integer> param1, List<List<Integer>> result, int[] nums) {
for (int i = start + 1; i < nums.length; i++) {
List<Integer> list = new ArrayList<>(param1);
list.add(nums[i]);
result.add(list);
//System.out.println(list);
diGui(i, list, result, nums);
}
}
public static List<List<Integer>> subsets(int[] nums) {
for (int k = 0;k<nums.length;k++){
for(int j = k+1;j<nums.length;j++){
if(nums[k]>nums[j]){
int temp = nums[k];
nums[k] = nums[j];
nums[j] =temp;
}
}
}
List<List<Integer>> result = new ArrayList<>();
for (int i = 0; i < nums.length; i++) {
List<Integer> param1 = new ArrayList<>();
param1.add(nums[i]);
result.add(param1);
diGui(i, param1, result, nums);
}
List<Integer> noParam = new ArrayList<>();
result.add(noParam);
return result;
}
public static void main(String[] args) {
int[] param = {5,2,3,4};
System.out.println(subsets(param));
}
}