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 条评论