给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: [1,2,2] 输出: [ [2], [1], [1,2,2], [2,2], [1,2], [] ]
class Solution:
def subsetsWithDup(self, nums: List[int]) -> List[List[int]]:
def dfs(nums, i, res, path):
res.append(copy.deepcopy(path))
for j in range(i, len(nums)):
if j != i and nums[j] == nums[j - 1]:
continue
path.append(nums[j])
dfs(nums, j + 1, res, path)
path.pop()
res, path = [], []
nums.sort()
dfs(nums, 0, res, path)
return res
class Solution {
public List<List<Integer>> subsetsWithDup(int[] nums) {
List<Integer> path = new ArrayList<>();
List<List<Integer>> res = new ArrayList<>();
Arrays.sort(nums);
dfs(nums, 0, res, path);
return res;
}
private void dfs(int[] nums, int i, List<List<Integer>> res, List<Integer> path) {
res.add(new ArrayList<>(path));
for (int j = i; j < nums.length; ++j) {
if (j != i && nums[j] == nums[j - 1]) {
continue;
}
path.add(nums[j]);
dfs(nums, i + 1, res, path);
path.remove(path.size() - 1);
}
}
}