首页
/
每日頭條
/
生活
/
算法的經典例題
算法的經典例題
更新时间:2026-03-05 16:57:02

算法的經典例題?給定一組不含重複元素的整數數組 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
推荐阅读
備考省考需要多少時間
備考省考需要多少時間
還沒有開始備考的考生,一定要馬上開始備考,因為省考備考至少需要學習300小時才有可能上岸。每年備考省考的考生,在考前都要刷該省近五年的試卷,為的是了解本省試卷結構,提前規劃好做題時間。還要刷近五年國考試卷,因為每年國考都會為省考備考指明方向...
2026-03-05
微信怎麼恢複删除的聊天記錄
微信怎麼恢複删除的聊天記錄
微信怎麼恢複删除的聊天記錄?使用電腦端備份恢複,打開電腦端微信,點擊左下角的“備份與恢複”,我來為大家講解一下關于微信怎麼恢複删除的聊天記錄?跟着小編一起來看一看吧!微信怎麼恢複删除的聊天記錄使用電腦端備份恢複,打開電腦端微信,點擊左下角的...
2026-03-05
最好的寬心詩句
最好的寬心詩句
《西江月·世事短如春夢》【宋】朱敦儒世事短如春夢,人情薄似秋雲。不須計較苦勞心,萬事原來有命。幸遇三杯酒好,況逢一朵花親。片時歡笑且相親,明日陰晴未定。《花下酌酒歌》【明】唐寅九十春光一擲梭,花前酌酒唱高歌。枝上花開能幾日,世上人生能幾何。...
2026-03-05
樓上和樓下噪音太大怎麼辦
樓上和樓下噪音太大怎麼辦
【共存】——生活與噪音共存長沙的商品房大多是高層,沒有誰家是獨立承重,無論是牆體、地闆、樓闆都是連在一起的,這就有了一種很常見現象:同一棟樓,每家每戶都有着不同的生活方式和習慣,同一個時間段,有的人已經睡覺了、有的正搬桌拉椅的打掃、有的熊孩...
2026-03-05
美國為什麼沒打赢越南
美國為什麼沒打赢越南
在美、日、印、澳舉行四國聯合軍演,白宮費苦心拉攏韓國之時,印太地區的一個重量級玩家越南,卻選擇了"坐山觀虎鬥"。很顯然,在要不要迎接美軍入駐、該不該抱美國大腿的問題上,越南是非常猶豫不決的。一方面,越南内部的親美派認為,在國...
2026-03-05
Copyright 2023-2026 - www.tftnews.com All Rights Reserved