LCR 079. 子集 - 力扣(LeetCode)
方法一
代码实现
class Solution {
List<List<Integer>> ret;
List<Integer> path;
public List<List<Integer>> subsets(int[] nums) {
ret = new ArrayList<>();
path = new ArrayList<>();
dfs(nums,0);
return ret;
}
public void dfs(int[] nums,int i){
// 递归出口
if(i == nums.length){
ret.add(new ArrayList(path));
return;
}
// 选
path.add(nums[i]);
dfs(nums,i+1);
// 回溯,恢复现场
path.remove(path.size()-1);
// 不选
dfs(nums,i+1);
}
}
方法二
代码实现
class Solution {
List<List<Integer>> ret;
List<Integer> path;
public List<List<Integer>> subsets(int[] nums) {
ret = new ArrayList<>();
path = new ArrayList<>();
dfs(nums,0);
return ret;
}
public void dfs(int[] nums,int i){
// 每个节点都是子集,进入就添加到 ret 中
ret.add(new ArrayList(path));
for(int j=i;j<nums.length;j++){ // 从节点 i 开始
path.add(nums[j]);
dfs(nums,j+1);
// 回溯,恢复现场
path.remove(path.size()-1);
}
}
}