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);
    }
相關文章
相關標籤/搜索