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

算法的經典例題?給定一組不含重複元素的整數數組 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
推荐阅读
現在世界女乒個人排名
現在世界女乒個人排名
7月份的WTT比賽結束,比賽的最新成果:世界排名又出來了。在女子組方面,中日女乒是兩個老對手,兩隊不僅在“賽場上”較勁,而且在“排行榜上”也是你追我趕,每一次都有新變化。下面,把本次“完整的前10排名”和“雙方前20排名”情況,列舉如下:第...
2026-05-24
南京好吃又便宜的面館
南京好吃又便宜的面館
不太餓,不想吃飯的情況時常有,但是面,好像就沒有吃不下去的時候——仿佛吃面啟用的是另一個胃,随時都可以來上一碗。特别是最近溫度降下來之後,對吃面的熱情又嘎嘎提了上來。吃面,如果用一篇文章證明我局是認真的,請戳《測評魔都面館225家,頂尖的都...
2026-05-24
ai夢境檔案用什麼玩
ai夢境檔案用什麼玩
《AI夢境檔案涅槃計劃》發行商SpikeChunsoft今日帶來了更多關于本作的全新截圖以及遊戲情報。遊戲由調查和Somnium兩部分組成,"調查"部分發生在真實的世界,在這裡玩家将檢查犯罪現場,并聽取證詞。在"Somnium"的部分,玩家...
2026-05-24
甯這個姓氏在百家姓中排位
甯這個姓氏在百家姓中排位
甯姓在宋版《百家姓》中排名第241位。甯姓是當今中國姓氏排行第一百八十七位的姓氏,約占全國漢族人口的百分之零點零五。姓氏起源源于姬姓甯氏的遠祖乃是周文王姬昌第九子姬封,因他初封于康,後人稱他為康叔。據史籍《元和姓纂》中記載:“甯,衛康叔之後...
2026-05-24
春季妝容不服帖
春季妝容不服帖
春季妝容不服帖?妝前要先做好保濕無論你是幹性、中性、還是油性肌膚,上妝前都是不能忽略掉皮膚保濕這一步驟的,因為這一步才是整個妝容持久度的關鍵任何肌膚在不同環境之下,都會面臨幹燥的問題,而對于那些皮膚出油量旺盛的人而言,這也可能是皮膚缺水的原...
2026-05-24
Copyright 2023-2026 - www.tftnews.com All Rights Reserved