题目描述:
给你一个整数数组 nums ,数组中的元素 互不相同。返回该数组所有可能的子集(幂集)。
解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
题目链接:LeetCode-78-子集
解题思路:递归回溯
题目的要求是不能有重复的子集,其实给的数组是互不相同的,按照普通递归思路就好了。文章来源:https://www.toymoban.com/news/detail-707911.html
代码实现:文章来源地址https://www.toymoban.com/news/detail-707911.html
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);
}
}
}
到了这里,关于LeetCode-78-子集的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!