18 带重复元素的子集

原题网址:https://www.lintcode.com/zh-cn/problem/subsets-ii/

给定一个可能具有重复数字的列表,返回其所有可能的子集

 注意事项
  • 子集中的每个元素都是非降序的
  • 两个子集间的顺序是无关紧要的
  • 解集中不能包含重复子集
样例

如果 S = [1,2,2],一个可能的答案为:

[
  [2],
  [1],
  [1,2,2],
  [2,2],
  [1,2],
  []
]
挑战 

你可以同时用递归与非递归的方式解决么?

标签 

 

方法1. 参考15、16题,可以非常鸡贼的设置一个判断数组是否已存在于二维数组result中的函数,然后还是子集的代码,只不过插入数组到result中前判断一下result中是否已存在该数组,嗯……

AC代码:

class Solution {
public:
    /**
     * @param nums: A set of numbers.
     * @return: A list of lists. All valid subsets.
     */
    vector<vector<int>> subsetsWithDup(vector<int> &nums) {
        // write your code here
        vector<vector<int>> result;
    if (nums.empty())
    {
        result.push_back(nums);
        return result;
    }
    sort(nums.begin(),nums.end());
    vector<int> first;
    first.push_back(nums[0]);
    result.push_back(first);

    for (int i=1;i<(int)nums.size();i++)
    {
        int size1=result.size();
        for (int j=0;j<size1;j++)
        {
            vector<int> temp1= result[j];
            temp1.push_back(nums[i]);
            if (!isExist(result,temp1))
            {
                result.push_back(temp1);
            }
        }
        vector<int> temp2;
        temp2.push_back(nums[i]);
        if (!isExist(result,temp2))
        {
            result.push_back(temp2);
        }
        
    }
    vector<int> nul;
    result.push_back(nul);
    return result;
    }
    
    bool isSameNum(vector<int> num1,vector<int> num2)
{
    if (num1.size()!=num2.size())
    {
        return false;
    }
    for (int i=0;i<(int)num1.size();i++)
    {
        if (num1[i]!=num2[i])
        {
            return false;
        }
    }
    return true;
}

bool isExist(vector<vector<int>> result,vector<int> num)
{
    if (result.empty())
    {
        return false;
    }
    for (int i=0;i<(int)result.size();i++)
    {
        if (isSameNum(num,result[i]))
        {
            return true;
        }            
    }
    return false;
}

};

其他方法:https://www.cnblogs.com/felixfang/p/3775712.html  可以多啃几遍

 

非递归:https://blog.csdn.net/lhanchao/article/details/54629065

递归:https://www.jianshu.com/p/557788c1dcc1

转载于:https://www.cnblogs.com/Tang-tangt/p/8947599.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
重复元素子集问题是指给定一个可能包含重复元素的整数数组,要求返回所有不重复子集。关于这个问题的解决方法,可以采用深度优先遍历DFS法。 具体做法是将数组中的每个元素看作二叉树的一个节点,通过DFS的方式逐个遍历每个节点。与遍历二叉树的所有路径类似,但需要在递归右子树之前将新添加的元素弹出,以避免重复。 这个问题和其他一些问题,比如两个数字相加、无重复字符的最长子串、两个有序数组的中位数等类似,也可以通过递归和循环来解决。使用for循环的原因是,在多叉树的情况下,可以通过循环遍历每个子节点的选择列表,然后将选择的子节点作为当前节点进行递归调用。而在二叉树的情况下,则可以使用两个并列的递归。 总结起来,重复元素子集问题可以通过深度优先遍历DFS法来解决,也可以使用递归和循环的方式来求解。在实际编程中,可以根据具体情况选择合适的方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [leetcode 78.不含重复元素数组的子集](https://blog.csdn.net/zy450271923/article/details/105701584)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [lrucacheleetcode-Leetcode-Questions:面试编码问题](https://download.csdn.net/download/weixin_38694800/19916021)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值