Lintcode17 Subsets solution 题解

【题目描述】

Given a set of distinct integers, return all possible subsets.

Notice:Elements in a subset must be in non-descending order;The solution set must not contain duplicate subsets.

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

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

【题目链接】

http://www.lintcode.com/en/problem/subsets/

【题目解析】

子集类问题类似Combination,以输入数组[1, 2, 3]分析,根据题意,最终返回结果中子集类的元素应该按照升序排列,故首先需要对原数组进行排序。题目的第二点要求是子集不能重复,至此原题即转化为数学中的组合问题。我们首先尝试使用 DFS 进行求解,大致步骤如下:

[1] -> [1, 2] -> [1, 2, 3]

[2] -> [2, 3]

[3]

将上述过程转化为代码即为对数组遍历,每一轮都保存之前的结果并将其依次加入到最终返回结果中。

【答案链接】

http://www.jiuzhang.com/solution/subsets/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,768评论 0 33
  • 【题目描述】 Given a list of numbers that may has duplicate num...
    代码码着玩阅读 542评论 0 0
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 17,909评论 2 36
  • 先决条件 在阅读这个教程之前,你多少需要知道点python。如果你想从新回忆下,请看看Python Tutoria...
    舒map阅读 2,601评论 1 13
  • 一:标题 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 二:列表 无序列表 文本1 文本2 文本3 ...
    Leo_hai阅读 515评论 0 2