首页
/
每日頭條
/
生活
/
算法的經典例題
算法的經典例題
更新时间:2026-04-21 05:54:46

算法的經典例題?給定一組不含重複元素的整數數組 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
推荐阅读
仙劍奇俠傳2千葉第二次怎麼打
仙劍奇俠傳2千葉第二次怎麼打
仙劍奇俠傳2千葉第二次怎麼打?千葉的第一個形态打不赢第二個狀态,定身之後把所有的武器什麼的都扔給他,今天小編就來聊一聊關于仙劍奇俠傳2千葉第二次怎麼打?接下來我們就一起去研究一下吧!仙劍奇俠傳2千葉第二次怎麼打千葉的第一個形态打不赢。第二個...
2026-04-21
女性内衣内褲多久換一次正常
女性内衣内褲多久換一次正常
大家平時穿的内衣、内褲都多久更換一次呢?雖然這個話題有一點羞羞的,可是如果做錯了,會影響我們的身體健康哦!大家不要覺得這個問題隻針對女生,無論男生女生都是一樣的,内衣褲如果長時間不換就會滋生細菌!男生一般是三五天更換一次内褲,有甚者還會穿更...
2026-04-21
大吉大利是什麼生肖
大吉大利是什麼生肖
大吉大利是什麼生肖?雞,諧音“吉”,寓意大吉大利相傳雞王争強好勝,惹事生非玉帝封生肖時,未曾考慮它已經封為生肖的馬王告訴雞王,要得到人們愛戴,就需發揮自己長處,為人們做出貢獻雞王左思右想,最後決定用自己的金嗓子喚醒沉睡的人們,于是每天拂曉,...
2026-04-21
爽身粉過期了還能用嗎
爽身粉過期了還能用嗎
爽身粉過期了還能用嗎?爽身粉過期不能用爽身粉含有氧化鎂、硫酸鎂,過期的爽身粉的産品功能及效果穩定性方面會有所降低,甚至有危害,建議不要使用爽身粉因所含硼酸成分不同,分為成人用和兒童用兩種爽身粉除了能吸收汗液,滑爽皮膚,也可減少痱子發生,下面...
2026-04-21
校園消防知識教育内容
校園消防知識教育内容
#開學#【校園消防安全指南】學校作為人員密集場所,消防安全尤為重要,學生們一定要牢記校園用電及防火安全要求,校園裡還有哪些需要注意的消防安全事項?今天就和藍朋友一起上一堂校園消防安全課吧↓↓↓#男孩趕作業敲得比發電報還快##消防知識#​​​...
2026-04-21
Copyright 2023-2026 - www.tftnews.com All Rights Reserved