LintCode 17.子集
Posted lvjunlong
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LintCode 17.子集相关的知识,希望对你有一定的参考价值。
/** * 描述 给定一个含不同整数的集合,返回其所有的子集 子集中的元素排列必须是非降序的,解集必须不包含重复的子集 样例 如果 S = * [1,2,3],有如下的解: [ [3], [1], [2], [1,2,3], [1,3], [2,3], [1,2], [] ] 挑战 * 你可以同时用递归与非递归的方式解决么? */ @Test public static List<List<Integer>> subsets(int[] nums) { // write your code here ArrayList<List<Integer>> res = new ArrayList<List<Integer>>(); ArrayList<Integer> list = new ArrayList<Integer>(); if (nums == null || nums.length == 0) { return res; } res.add(list); Arrays.sort(nums); System.out.println("排序后的数组:" + nums.toString()); for (int i = 0; i < nums.length; i++) { for (int j = 0; j < Math.pow(2, i); j++) {// 每一层的个数都是2的n次方 System.out.println(Math.pow(2, i)); List<Integer> temp = res.get(0); res.remove(0);// 把第一个取出来 ArrayList<Integer> temp2 = new ArrayList<Integer>(temp); temp2.add(temp2.size(), nums[i]); res.add(temp2);// 加入一个数,放进去 res.add(temp);// 不加数,放进去 } System.out.println(res.toString()); } System.out.println("最终:" + res.toString()); return res; } public static void main(String[] args) { int[] nums = { 1, 2, 3 }; subsets(nums); }
以上是关于LintCode 17.子集的主要内容,如果未能解决你的问题,请参考以下文章