题目链接:https://leetcode.cn/problems/subsets-ii/
方法一 回溯
1 方法思想
2 代码实现
class Solution {
List<List<Integer>> result = new ArrayList<>();
LinkedList<Integer> combine = new LinkedList<>();
public List<List<Integer>> subsetsWithDup(int[] nums) {
Arrays.sort(nums);
backTracking(nums, 0);
return result;
}
public void backTracking(int[] nums, int start) {
if (start <= nums.length) {
result.add(new ArrayList<>(combine));
}
for (int i = start; i < nums.length; i++) {
if (i != start && nums[i] == nums[i - 1]) {
continue;
}
combine.add(nums[i]);
backTracking(nums, i + 1);
combine.removeLast();
}
}
}
3 复杂度分析
时间复杂度:
空间复杂度: