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;

        }
    }
};
相关推荐
独自破碎E21 小时前
【DFS】BISHI76 迷宫寻路
算法·深度优先
代码无bug抓狂人1 天前
C语言之单词方阵——深搜(很好的深搜例题)
c语言·开发语言·算法·深度优先
码农幻想梦1 天前
3472. 八皇后(北京大学考研机试题目)
考研·算法·深度优先
重生之后端学习1 天前
74. 搜索二维矩阵
开发语言·数据结构·算法·职场和发展·深度优先
觅特科技-互站1 天前
实测:接入陌讯Skills后Copilot任务完成率↑63%、调试耗时↓90%
线性回归·深度优先·copilot
重生之后端学习1 天前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
zaiyang遇见1 天前
[GESP202509 六级] 货物运输
深度优先·贪心·树的遍历·gesp六级·树的存储
筱昕~呀1 天前
冲刺蓝桥杯-DFS板块(第二天)
算法·蓝桥杯·深度优先
每天要多喝水1 天前
图论Day39:孤岛题目
算法·深度优先·图论
独自破碎E1 天前
【DFS】BISHI77数水坑
算法·深度优先