首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >LintCode-17. 子集

LintCode-17. 子集

作者头像
悠扬前奏
发布2019-05-31 10:24:52
发布2019-05-31 10:24:52
3620
举报

题目

描述

给定一个含不同整数的集合,返回其所有的子集

注意事项:子集中的元素排列必须是非降序的,解集必须不包含重复的子集

样例

如果 S = [1,2,3],有如下的解:

代码语言:javascript
复制
[
  [3],
  [1],
  [2],
  [1,2,3],
  [1,3],
  [2,3],
  [1,2],
  []
]

解答

思路

从空集开始,每个整数和所有子集组成的集合中的各子集都能组成新的子集。 根据注意事项,整数加入子集之后需要进行排序。

代码

代码语言:javascript
复制
public class Solution {
    
    /*
     * @param nums: A set of numbers
     * @return: A list of lists
     */
    public List<List<Integer>> subsets(int[] nums) {
        // write your code here
        List<List<Integer>>  aList = new ArrayList<List<Integer>>();
        aList.add(new ArrayList<Integer>());
        for (int num : nums){
            int size =  aList.size();
            for(int i =  0; i < size; i++){
                List<Integer> temp = new ArrayList<>(aList.get(i));
                temp.add(num);
                Collections.sort(temp);
                aList.add(temp);
            }
        }
        return aList;
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.02.27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
    • 描述
    • 样例
  • 解答
    • 思路
    • 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档