子集 II
题目:
给你一个整数数组 nums ,其中可能包含重复元素,请你返回该数组所有可能的子集(幂集)。
解集 不能 包含重复的子集。返回的解集中,子集可以按 任意顺序 排列。
示例 1:
输入:nums = [1,2,2]
输出:[[],[1],[1,2],[1,2,2],[2],[2,2]]
示例 2:
输入:nums = [0]
输出:[[],[0]]
class Solution {
public List<List<Integer>> subsetsWithDup(int[] nums) {
Set<List<Integer>> ans = new HashSet();
Arrays.sort(nums);
dfs(nums, ans, new ArrayList(), 0);
return new ArrayList(ans);
}
private void dfs(int[] nums, Set<List<Integer>> ans, List<Integer> list, int cur) {
ans.add(new ArrayList<>(list));
for (int j = cur; j < nums.length; j++) {
list.add(nums[j]);
dfs(nums, ans, list, j + 1);
list.remove(list.size() - 1);
}
}
}
class Solution {
public List<List<Integer>> subsetsWithDup(int[] nums) {
List<List<Integer>> ans = new ArrayList();
Arrays.sort(nums);
dfs(false, nums, ans, new ArrayList(), 0);
return ans;
}
private void dfs(boolean isChoosePre, int[] nums, List<List<Integer>> ans, List<Integer> list, int cur) {
if(cur == nums.length) {
ans.add(new ArrayList(list));
return ;
}
dfs(false, nums, ans, list, cur + 1);
if(!isChoosePre && cur != 0 && nums[cur - 1] == nums[cur]) {
return ;
}
list.add(nums[cur]);
dfs(true, nums, ans, list, cur + 1);
list.remove(list.size() - 1);
}
}