网站建设相关职业岗位世界杯比分
题目描述:
给你一个整数数组 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);}}
}