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;

        }
    }
};
相关推荐
木井巳8 小时前
【DFS解决floodfill算法】岛屿数量
java·算法·leetcode·深度优先
兰令水1 天前
leecodecode【回溯子集】【2026.6.4打卡-java版本】
java·开发语言·深度优先
王老师青少年编程3 天前
信奥赛C++提高组csp-s之搜索进阶(搜索剪枝核心思想 )
c++·dfs·csp·信奥赛·搜索剪枝·搜索优化
星马梦缘3 天前
死锁与进程资源分配问题的解法
算法·操作系统·深度优先·死锁
ʚ希希ɞ ྀ4 天前
全排列 --- 回溯
算法·leetcode·深度优先
Lsk_Smion4 天前
力扣实训 _ [200].岛屿数量
算法·leetcode·深度优先
fengenrong4 天前
20260601
算法·深度优先·图论
ʚ希希ɞ ྀ5 天前
岛屿数量 -- 图论
算法·深度优先·图论
yuanyuan2o25 天前
模型预训练:Hugging Face Transformers 基础
算法·ai·语言模型·自然语言处理·nlp·深度优先
菜菜的顾清寒5 天前
力扣HOT100(47) 二叉树的层序遍历
算法·leetcode·深度优先