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

算法的經典例題?給定一組不含重複元素的整數數組 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-05-19
夏天家常湯好喝又簡單
夏天家常湯好喝又簡單
炎炎夏日,大家是不是都有這種感受,不敢動,稍微動一下就汗如雨下。夏天出汗多,鈣流失也非常快。很多人吃飯都沒有胃口,吃啥都不香,更别說喝湯了。但是你知道嗎?夏天就是要多喝湯,有句俗話說:“夏天一碗湯,郎中不用幫”。湯中的營養成分都是水溶性的,...
2026-05-19
印太戰略的應對之道
印太戰略的應對之道
特朗普就任以來唯一不敢否認、從未推倒重來的就是他競選伊始所提出的新口号——“美國第一”。古人雲“人存政舉,人亡政息”。如今奧巴馬走了,他執政中後期提出的“亞太再平衡”戰略也鮮被提起,似乎早已壽終正寝。然而,針對中國的“亞太再平衡”戰略就真的...
2026-05-19
非人哉新角色排名
非人哉新角色排名
《非人哉》漫畫最新兩話中,登場了三名新角色。這種突然出現的角色,看起來與其他角色沒有關聯,但從蛛絲馬迹中可以看出,其實這三名角色都是有迹可循。其中狐老弟是九月的爸爸可能性極大,被求愛的妹子,從外表來看,應該就是哪吒的母親。針對這三位新角色,...
2026-05-19
什麼是通貨膨脹?
什麼是通貨膨脹?
什麼是通貨膨脹?通貨膨脹是造成一國貨币貶值的物價上漲通貨膨脹和一般物價上漲的本質區别:一般物價上漲是指某個、某些商品因為供求失衡造成物價暫時、局部、可逆的上漲,不會造成貨币貶值;通貨膨脹則是能夠造成一國貨币貶值的該國國内主要商品的物價持續、...
2026-05-19
Copyright 2023-2026 - www.tftnews.com All Rights Reserved