zoukankan      html  css  js  c++  java
  • 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);
        }
  • 相关阅读:
    hdu 2106 decimal system
    00-自测4. Have Fun with Numbers (20)
    07-图4. Saving James Bond
    hdu 2209 翻纸牌游戏
    hdu 1272 小希的迷宫
    1969 Pie
    怎样维护 SQLite
    Navicat使用亮点
    Navicat for MySQL 11 Mac安装教程
    Navicat for PostgreSQL 运算符有哪些类别
  • 原文地址:https://www.cnblogs.com/lvjunlong/p/9367419.html
Copyright © 2011-2022 走看看