首页
/
每日頭條
/
生活
/
算法的經典例題
算法的經典例題
更新时间:2026-02-28 09:41:47

算法的經典例題?給定一組不含重複元素的整數數組 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
推荐阅读
見好就收拿了就走
見好就收拿了就走
之前在每日文章多次提到大元泵業這隻股票。今天它在我賣出時又漲停了。我曾有幸的因為這隻股票收益700多。但今天親眼見證了曆史。它跌停了。當然,目前跌停的價格也比我之前賣出的高。不過我已經不在為之前的早賣出而後悔了。我有點欣慰自己的見好就收。除...
2026-02-28
我的願望作文300字
我的願望作文300字
我的願望作文300字?“轟隆隆、轟隆隆……”伴随着一聲聲震耳欲聾的巨響,一幢幢房屋都像積木似的倒了下來,瞬間,許多鮮活的生命都被埋在了廢墟裡,這些情景我隻在電影裡看到過可是現在,它卻活生生地發生在四川省汶川縣汶川……一個曾經風景如畫的地方我...
2026-02-28
寶駿360的質量怎麼樣
寶駿360的質量怎麼樣
我自己拿到駕照十幾年了,而且還是B照,中間給人開過貨車,也開過出租車,現在自己在家開一個煙酒商行,雖然說生意不怎麼大,但是好歹也可以養家糊口。從去年春天開始,我就自己研究着要買一輛汽車了,畢竟要拿電動三輪車給人家送貨,有時候會裝不下,自己家...
2026-02-28
商務區最好的房子評測
商務區最好的房子評測
在《2020年深圳市計劃入市商品房》列表中,大多數人都把目光集中在潤四和海岸城上,其實還有一個小衆明星盤值得關注,它就是位于前海蛇口自貿區的新世界臨海攬山禦園。深圳看房團實地考察後,為讀者帶來該項目的客觀分析:早在去年11月,團長就關注了臨...
2026-02-28
辣條吃多了對身體有什麼危害
辣條吃多了對身體有什麼危害
近日在央視的315晚會上面,揭露了一大批問題産品,其中我們生活中比較常見的五毛錢一包的“辣條”也是榜上有名,根據記者的跟蹤走訪,在一些小學門口的小店,售賣辣條生意異常火爆,有些小學生一買就是好幾包。辣條的外包裝看起來髒污,衛生安全也是堪憂,...
2026-02-28
Copyright 2023-2026 - www.tftnews.com All Rights Reserved