Leetcode之回溯法专题-90. 子集 II(Subsets II)
给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: [1,2,2] 输出: [ [2], [1], [1,2,2], [2,2], [1,2], [] ]
分析:是78题的升级版,新增了一些限制条件,nums数组是会重复的,求子集。
class Solution { List<List<Integer>> ans = new ArrayList<>(); public List<List<Integer>> subsetsWithDup(int[] nums) { if(nums.length==0) return ans; dfs(nums,0,new ArrayList<Integer>()); return ans; } public void dfs(int[] nums,int step,ArrayList<Integer> list){ if(step>=nums.length){ List<Integer> tmp = new ArrayList<>(list); Collections.sort(tmp); if(!ans.contains(tmp)){ ans.add(new ArrayList<>(tmp)); } return; } list.add(nums[step]); dfs(nums,step+1,list); list.remove(list.size()-1); dfs(nums,step+1,list); } }