78. Subsets 子集

題目鏈接
tag:

  • Medium

question:
??Given a set of distinct integers, nums, return all possible subsets (the power set).

Note: The solution set must not contain duplicate subsets.

Example:

Input: nums = [1,2,3]
Output:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]

思路:
??這道求子集合的問題,由于其要列出所有結(jié)果,按照以往的經(jīng)驗(yàn),肯定要是要用遞歸來做。這道題其實(shí)它的非遞歸解法相對(duì)來說更簡單一點(diǎn),下面我們先來看非遞歸的解法,由于題目要求子集合中數(shù)字的順序是非降序排列的,所有我們需要預(yù)處理,先給輸入數(shù)組排序,然后再進(jìn)一步處理,最開始我在想的時(shí)候,是想按照子集的長度由少到多全部寫出來,比如子集長度為0的就是空集,空集是任何集合的子集,滿足條件,直接加入。下面長度為1的子集,直接一個(gè)循環(huán)加入所有數(shù)字,子集長度為2的話可以用兩個(gè)循環(huán),但是這種想法到后面就行不通了,因?yàn)檠h(huán)的個(gè)數(shù)不能無限的增長,所以我們必須換一種思路。我們可以一位一位的網(wǎng)上疊加,比如對(duì)于題目中給的例子[1,2,3]來說,最開始是空集,那么我們現(xiàn)在要處理1,就在空集上加1,為[1],現(xiàn)在我們有兩個(gè)自己[]和[1],下面我們來處理2,我們在之前的子集基礎(chǔ)上,每個(gè)都加個(gè)2,可以分別得到[2],[1, 2],那么現(xiàn)在所有的子集合為[], [1], [2], [1, 2],同理處理3的情況可得[3], [1, 3], [2, 3], [1, 2, 3], 再加上之前的子集就是所有的子集合了,代碼如下:

class Solution {
public:
    vector<vector<int> > subsets(vector<int> &S) {
        vector<vector<int> > res(1);
        sort(S.begin(), S.end());
        for (int i = 0; i < S.size(); ++i) {
            int size = res.size();
            for (int j = 0; j < size; ++j) {
                res.push_back(res[j]);
                res.back().push_back(S[i]);
            }
        }
        return res;
    }
};
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Question Given a set of distinct integers, nums, return a...
    GhostintheCode閱讀 2,976評(píng)論 0 0
  • 動(dòng)態(tài)規(guī)劃 111. 爬樓梯思路類似斐波那契數(shù)列注意考慮第 0 階的特殊情況 272. 爬樓梯 II思路類似上題,只...
    6默默Welsh閱讀 2,603評(píng)論 0 1
  • <center>#51 N-Queens</center> link Description:The n-quee...
    鐺鐺鐺clark閱讀 1,117評(píng)論 0 0
  • LeetCode 刷題隨手記 - 第一部分 前 256 題(非會(huì)員),僅算法題,的吐槽 https://leetc...
    蕾娜漢默閱讀 18,392評(píng)論 2 36
  • 今天挑戰(zhàn)早起成功了,五點(diǎn)我準(zhǔn)時(shí)起床聽虛受老師的課程,今天做了一些筆記,讓我學(xué)會(huì)了要保持安靜,多說無益,話多讓人討厭...
    倪梓睿閱讀 220評(píng)論 0 0

友情鏈接更多精彩內(nèi)容