算法练习第24天|78.子集、 90.子集II

发布于:2024-05-23 ⋅ 阅读:(123) ⋅ 点赞:(0)

 78.子集

78. 子集 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/subsets/

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;

    void backTracking(vector<int> & nums, int startIndex){
        if(startIndex == nums.size()){
            return;
        }

        for(int i = startIndex; i<nums.size(); i++){
            path.push_back(nums[i]); //记录节点
            result.push_back(path);  //result直接记录
            backTracking(nums, i+1);
            path.pop_back();
        }
    }

    vector<vector<int>> subsets(vector<int>& nums) {
        result.clear();
        path.clear();
        result.push_back(path); //空集
        backTracking(nums,0);
        return result;
    }
};

  90.子集II

90. 子集 IIicon-default.png?t=N7T8https://leetcode.cn/problems/subsets-ii/去除重复元素带来的重复子集,其思想与第40题组合总和II一样,可以参考这篇文章:算法练习第22天|39. 组合总和、40.组合总和II-CSDN博客

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    void backTracking(vector<int>& nums, int startIndex){
        if(startIndex == nums.size()){
            return;
        }

        for(int i = startIndex; i < nums.size(); i++){
            //重复发生在同一树层的非左树枝,非左树枝用i>startIndex限制,相同元素是排序后当前元素等于其前一个元素
            if(i > startIndex && nums[i] == nums[i-1])
                continue;
            path.push_back(nums[i]);
            result.push_back(path);
            backTracking(nums,i+1);
            path.pop_back();
        }

    }
    vector<vector<int>> subsetsWithDup(vector<int>& nums) {
        result.clear();
        path.clear();
        sort(nums.begin(), nums.end());
        result.push_back(path);//空集
        backTracking(nums,0);
        return result;

    }
};


网站公告

今日签到

点亮在社区的每一天
去签到