题目描述:
给你一个整数数组 nums ,数组中的元素 互不相同。返回该数组所有可能的子集(幂集)。
解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
题目链接:LeetCode-78-子集
解题思路:递归回溯
题目的要求是不能有重复的子集,其实给的数组是互不相同的,按照普通递归思路就好了。
代码实现:
class Solution {
List<List<Integer>> res = new ArrayList<>();
List<Integer> path = new ArrayList<>();
public List<List<Integer>> subsets(int[] nums) {
backTracking(nums, 0);
return res;
}
public void backTracking(int[] nums, int index){
res.add(new ArrayList<>(path));// 需要注意的是现在每个节点都是一个解集,而不仅是叶子节点了
if (index >= nums.length){
return;
}
for (int i = index; i < nums.length; i++) {
path.add(nums[i]);
backTracking(nums, i+1);
path.remove(path.size()-1);
}
}
}