leetcode90. 子集 II

去重逻辑:

关键是画出递归树!当我们即将进入第二个2的递归的时候,发现isVisit数组是100,也就是说这俩重复的数是False,并且这俩在nums值相同,所以写出去重逻辑!

cpp 复制代码
class Solution {
public:
    vector<int>* pNums,*pArr=new vector<int>();
    vector<vector<int>> ans;
    vector<bool>* isVisit;
    vector<vector<int>> subsetsWithDup(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        pNums=&nums;
        isVisit=new vector<bool>(nums.size(),0);
        ans.push_back(vector<int>());
        dfs(0);
        return ans;
    }
    void dfs(int idx){
        if(idx>=pNums->size()){
            return;
        }
        for(int i=idx;i<pNums->size();++i){
            if(i>=1 && (*pNums)[i-1]==(*pNums)[i] && (*isVisit)[i-1]==0 && (*isVisit)[i]==0){ 
                continue;
            }
            if(!((*isVisit)[i])){
                pArr->push_back((*pNums)[i]);
                ans.push_back(*pArr);
                (*isVisit)[i]=1;
            }
            dfs(i+1);
            pArr->pop_back();
            (*isVisit)[i]=0;

        }
    }
};
相关推荐
某个默默无闻奋斗的人4 小时前
深度优先搜索(DFS)
算法·深度优先
KuaCpp11 小时前
搜索与图论复习1
算法·深度优先·图论
带多刺的玫瑰4 天前
Leecode刷题C语言之组合总和②
c语言·算法·深度优先
阿猿收手吧!4 天前
【力扣系列题目】最后一块石头的重量 分割回文串 验证回文串 等差数列划分{最大堆 背包 动态规划}
leetcode·深度优先·动态规划
Sunsets_Red4 天前
[ABC137E] Coins Respawn 题解
linux·c++·学习·算法·深度优先·信息与通信
xiao--xin4 天前
LeetCode100之子集(78)--Java
java·算法·leetcode·回溯
ke_wu4 天前
2025牛客寒假算法营3
算法·深度优先·图论
xiao--xin5 天前
LeetCode100之全排列(46)--Java
java·算法·leetcode·回溯
一缕叶5 天前
acwing搜索与图论(三)染色法
算法·深度优先·图论
LNsupermali6 天前
力扣111二叉树的最小深度(DFS)
算法·leetcode·深度优先