0
点赞
收藏
分享

微信扫一扫

递归&回溯&剪枝-子集

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);
}
}
}
举报

相关推荐

0 条评论