90. 子集 II

90. 子集 II

来源: LeetCode 90. 子集 II

题目描述

90. 子集 II
给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。

说明:解集不能包含重复的子集。

示例:

输入: [1,2,2]
输出:
[
  [2],
  [1],
  [1,2,2],
  [2,2],
  [1,2],
  []
]

思路分析

相对于子集无重复元素外,此时给出的列表里面含有重复元素,那么最关键的问题就是在去除重复上
对于求子集的过程中,如果在当前决策层次上之前已经判断过与其相同的数据那么该数据就是不需要判断的
res = new list;
def bacetrack(path, 选择列表)
	res.push(path)
	for choose in choose_list
		if(choose not done)
			path.add(choose) // 做出选择
			remove choose from choose_list
			bacetrack(path, new choose_list)
			path.delete(choose) // 取消该次选择
		else
			pass
if(choose not done) 可以通过对元数据进行排序如果当前数据和在其之前的数据相同,跳过

代码

class Solution {
public:
    vector<vector<int>> res;
    vector<int> _nums;
    vector<vector<int>> subsetsWithDup(vector<int>& nums) {
        sort(nums.begin(), nums.end()); // 排序确保相同元素聚集
        _nums = nums;
        vector<int> temp;
        subsetsWithDupRecur(0, temp);
        return res;
    }
    void subsetsWithDupRecur(int pos, vector<int>& arry){
        res.push_back(arry);
        for(int i=pos; i<_nums.size(); ++i){
            if(i > pos && _nums[i] == _nums[i-1]) continue; // 确保同一层级元素不重复
            arry.push_back(_nums[i]);
            subsetsWithDupRecur(i+1, arry);
            arry.pop_back();
        }
    } // 利用pos逐渐将选择从选择列表删除
};

算法分析

o(nlgn) + O(N!)

相似扩展

  • 相似题目
  • 升级版本
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值