首页 > 其他 > 详细

leetcode 子集

时间:2020-04-02 12:54:16      阅读:54      评论:0      收藏:0      [点我收藏+]
给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。

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

示例:

输入: nums = [1,2,3]
输出:
[
  [3],
  [1],
  [2],
  [1,2,3],
  [1,3],
  [2,3],
  [1,2],
  []
]

像这类题,选与不选,最开始想到的就是分情况递归。选1与不选1,同时要结合题意进行答案的输出。

子集包含空,最开始就把结果添加进去,然后每添加一个,就把结果添加进去。看了有的题解说的是回溯,我感觉回溯是会回头的方法,这道题的题意讲的是从不回头,因为1选了就不会再选1了,所以这里要设置现在的结果遍历到第几个了,以后都会从这个结果之后进行开始。

class Solution {
public:
    vector<vector<int>> r;
    vector<vector<int>> subsets(vector<int>& nums) {
         vector<int> res;
        solve(res,nums,0);
            return r;
    }
    void solve(vector<int> res, vector<int> nums, int start)
    {
        r.push_back(res);
        for(int i = start; i < nums.size(); i++)
        {
            res.push_back(nums[i]);
            solve(res,nums,i+1);
            res.pop_back();
        }
    }
};

 

leetcode 子集

原文:https://www.cnblogs.com/shilipojianshen/p/12618626.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!