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

算法的經典例題?給定一組不含重複元素的整數數組 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-06-08
電商積分如何處理
電商積分如何處理
今天,一個功能強大的平台揭開了面紗……平時交電費獲得的積分,在這個平台上既能自由兌入、兌出,又能抽獎、換購商品。不僅如此,通過積分聯盟,在航空公司、電商網站、銀行、通信運營商等不同平台的積分可以互相轉移、兌換,實現積分跨行業通兌!N個電商平...
2026-06-08
上海到蘇州高速封路了嗎
上海到蘇州高速封路了嗎
重要施工交通管制提醒:由于滬甯高速養護施工的需要:5日夜間20:00關閉蘇州收費站往上海方向匝道。同時關閉南京往上海、南通、杭州方向的轉向匝道。所有車輛請從蘇州收費站下高速繞行。(可以從婁江快速路、524省道、東環高架從滬甯高速園區收費站、...
2026-06-08
空調不制冷怎麼快速解決
空調不制冷怎麼快速解決
夏天到了,我們聽到最多的話,應該就是“好熱啊”,還好有空調,真的是很感謝發明空調的那個人,簡直是救了我的命啊!但是,最近有很多人跟我說過一個問題,空調隻吹風不制冷了怎麼辦?嗯,這個問題,我前不久才遇到過。已經解決了。空調不制冷有很多種原因,...
2026-06-08
粉紅色的花海周傑倫
粉紅色的花海周傑倫
粉紅色的花海周傑倫?“莫奈、梵高、達利、馬蒂斯還有徐志摩……哈哈,不讀點書,現在連周董的MV都看不懂……”7月6日,周傑倫新歌《最偉大的作品》播出後,有網友如此感慨也有網友稱這首歌的MV是周董版的《午夜巴黎》,因為在電影裡,主人翁和周董一樣...
2026-06-08
Copyright 2023-2026 - www.tftnews.com All Rights Reserved