首页
/
每日頭條
/
生活
/
算法的經典例題
算法的經典例題
更新时间:2026-03-12 18:44:37

算法的經典例題?給定一組不含重複元素的整數數組 nums,返回該數組所有可能的子集(幂集),下面我們就來聊聊關于算法的經典例題?接下來我們就一起去了解一下吧!

算法的經典例題(每天一道算法題)1

算法的經典例題

先來看下題目

給定一組不含重複元素的整數數組 nums,返回該數組所有可能的子集(幂集)。

說明:解集不能包含重複的子集。

示例:

輸入: nums = [1,2,3]

輸出:

[ [3], [1], [2], [1,2,3], [1,3], [2,3], [1,2], [] ]

思考過程

這道題是一道典型的考驗遞歸算法的題目,根據題目可以想到,[1,2,3]的子集是[1,2]裡面所有的子集和[1,2]裡面所有子集和3的組合加上[3]。

解題

var subsets = function(nums) { // 長度為1時結束遞歸 if (nums.length === 1) { return [[], [nums[0]]] } // 如果初始的長度就為0,則直接返回[[]] if (nums.length === 0) { return [[]] } // 取出最後一個數 const nowValue = nums.pop() // 剩下的數字做遞歸,找出剩下數字的所有子集 const childSubs = subsets(nums) // 對所有子集的長度賦值,因為這裡會在原數組上做修改,所以先記錄了原數組的長度 const subsLength = childSubs.length // 循環遍曆所有子集 for(let i = 0; i < subsLength; i ) { // 插入當前數和所有子集組合生成的新的子集 childSubs.push([...childSubs[i], nowValue]) } // 返回結果 return childSubs };

時間複雜度 O(N*2^N),生成所有子集,并複制到輸出結果中。

空間複雜度 O(N*2^N),這是子集的數量。

對于給定的任意元素,它在子集中有兩種情況,存在或者不存在(對應二進制中的 0 和 1)。因此,NN 個數字共有 2^N2N 個子集。

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
怎麼提神醒腦不犯困小妙招
怎麼提神醒腦不犯困小妙招
人們經常會在看書、學習、加班過程中犯困,一犯困,大腦就不清醒,效率就降低了,不僅要背的東西背不下來,還容易出錯,把數據弄錯了、把文字編輯錯了、一不小心還會把沒編輯完的郵件給發送出去了,等清醒的時候,真是懊惱,後悔莫及啊!今天小給大家介紹八種...
2026-03-12
好看炫酷壁紙高清全屏
好看炫酷壁紙高清全屏
,
2026-03-12
拉伸模具怎麼調整凸凹模間隙
拉伸模具怎麼調整凸凹模間隙
深拉伸産品(圓形/異形)在模具設計初始階段,要對産品進行展開即計算實現産品所需胚料的體積。我司經過多年的技術積累,已在此方面形成了相關的内部設計标準。在此主要從以下一個實例分享如何計算深拉伸産品的展開尺寸。實例一:圓形深拉伸産品展開尺寸計算...
2026-03-12
蘋果13promax卡頓怎麼回事
蘋果13promax卡頓怎麼回事
蘋果13promax卡頓怎麼回事?蘋果手機最大的優勢就在于系統的流暢性,但是在使用的過程中,有時候也是會出現卡頓的現象,現在小編就來說說關于蘋果13promax卡頓怎麼回事?下面内容希望能幫助到你,我們來一起看看吧!蘋果13promax卡頓...
2026-03-12
世界級生态島規劃
世界級生态島規劃
5月中旬,軌道交通崇明線選線專項規劃(草案)在市交通委官網結束了為期一個月的公示。這條開往世界級生态島的新地鐵線,離我們又近了一步。目前,項目的前期工作正在積極推進,将陸續進入建設項目環評和工程可行性研究報告審批等階段,今年年内有望開工。規...
2026-03-12
Copyright 2023-2026 - www.tftnews.com All Rights Reserved