Lintcode18 Subsets II solution 题解
2017-04-13 13:01
363 查看
【题目描述】
Given a list of numbers that may has duplicate numbers, return all possible subsets
Notice:Each element in a subset must be in non-descending order.The ordering between two subsets is free.The solution set must not contain duplicate subsets.
给定一个可能具有重复数字的列表,返回其所有可能的子集
注意:子集中的每个元素都是非降序的;两个子集间的顺序是无关紧要的;解集中不能包含重复子集
【题目链接】
http://www.lintcode.com/en/problem/subsets-ii/
【题目解析】
经典的DFS问题,如果有跟过九章微博的同学 应该会相当熟悉这个套路,跟前一个题目SubSet的区别是,有了重复的问题。怎么解决呢?
很简单。在每一次选数字的时候,只选第一个重复的数字,不选后面的,这样就不会有重复的set出现了。这里肯定有同学问了,如果你只选第一个,那222这种组合怎么弄出来?答案是:用递归时就不要考虑太多,只要考虑当前的情况。
例子: 1 2 2 2 2 3 4
那么你得到2 2 2 的过程是三层递归,每一层 都只选当前index开始的第一个2,所以2 2 2 还是可以组出来的。而且不会组出重复的,因为每一层递归你没有考虑重复,这就可以了。
还是要记住递归的精髓:考虑本层递归就好,别想太多
【答案链接】
https://www.jiuzhang.com/solutions/subsets-ii/
Given a list of numbers that may has duplicate numbers, return all possible subsets
Notice:Each element in a subset must be in non-descending order.The ordering between two subsets is free.The solution set must not contain duplicate subsets.
给定一个可能具有重复数字的列表,返回其所有可能的子集
注意:子集中的每个元素都是非降序的;两个子集间的顺序是无关紧要的;解集中不能包含重复子集
【题目链接】
http://www.lintcode.com/en/problem/subsets-ii/
【题目解析】
经典的DFS问题,如果有跟过九章微博的同学 应该会相当熟悉这个套路,跟前一个题目SubSet的区别是,有了重复的问题。怎么解决呢?
很简单。在每一次选数字的时候,只选第一个重复的数字,不选后面的,这样就不会有重复的set出现了。这里肯定有同学问了,如果你只选第一个,那222这种组合怎么弄出来?答案是:用递归时就不要考虑太多,只要考虑当前的情况。
例子: 1 2 2 2 2 3 4
那么你得到2 2 2 的过程是三层递归,每一层 都只选当前index开始的第一个2,所以2 2 2 还是可以组出来的。而且不会组出重复的,因为每一层递归你没有考虑重复,这就可以了。
还是要记住递归的精髓:考虑本层递归就好,别想太多
【答案链接】
https://www.jiuzhang.com/solutions/subsets-ii/
相关文章推荐
- Lintcode154 Regular Expression Matching solution 题解
- Lintcode183 Wood Cut solution 题解
- Lintcode54 String to Integer II solution 题解
- Lintcode70 Binary Tree Level Order Traversal II solution 题解
- LeetCode题解:Subsets I and II
- Lintcode119 Edit Distance solution 题解
- Lintcode49 Sort Letters by Case solution 题解
- Lintcode182 Delete Digits solution 题解
- Lintcode90 K Sum || solution 题解
- Lintcode164 Unique Binary Search Trees II solution 题解
- Lintcode190 Next Permutation II solution 题解
- [LeetCode] Linked List Cycle II, Solution
- lintcode coins-in-a-line-ii 硬币排成线ii
- Leetcode:best_time_to_buy_and_sell_stock_II题解
- [leetcode 78 & 90, Medium] Subsets I and II
- LintCode:线段树的查询II
- LeetCode题解:Word Break I and II
- 90.Subsets II leetcode java
- Lintcode76 Longest Increasing Subsequence solution 题解
- lintcode 42 最大子数组 II 解析