[leetcode]78

二次信任 提交于 2019-12-01 21:59:49

子集的规律:1,2,3
空集
添加1,形成(空集)-->1
添加2,形成(空集),(1),--> (2),(1,2)
添加3,形成(空集),(1),(2),(1,2)--->(3),(1,3),(2,3),(1,2,3)

class Solution {
public:
    vector<vector<int>> subsets(vector<int>& nums) {
        vector< vector<int> > subset;
        vector<int> empty;
        subset.push_back(empty);//空集

        for (int i = 0; i < nums.size(); i++)//对于集合中的每一个元素
        {
            vector< vector<int> > subsetTemp = subset;
            //对于当前的子集,添加进当前的元素
            for (int j = 0; j < subsetTemp.size(); j++)
                subsetTemp[j].push_back(nums[i]);
            //将添加后的子集再添加到子集中去
            for (int j = 0; j < subsetTemp.size(); j++)
                subset.push_back(subsetTemp[j]);
        }
        return subset;
    }
};
Runtime: 4 ms, faster than 97.62% of C++ online submissions for Subsets.
Memory Usage: 9.1 MB, less than 91.53% of C++ online submissions for Subsets.
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!