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

算法的經典例題?給定一組不含重複元素的整數數組 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-01-11
碧血劍袁承志絕世劍法
碧血劍袁承志絕世劍法
第一,穆人清。華山派掌門,外号神劍仙猿,武功出神入化,二十餘年未逢對手,劍法、拳術在《碧血劍》中舉世無雙。有三名弟子,分别是“銅筆鐵算盤”黃真、“神拳無敵”歸辛樹,主角袁承志。第二、袁承志。《碧血劍》一書男主角,袁崇煥之子,名為承志,意思是...
2026-01-11
小浣熊和幹脆面的區别
小浣熊和幹脆面的區别
曾經的xxx幹脆面承載着一代人滿滿的回憶,包裝上那個蠢萌的神獸一度被認為是小浣熊。“然鵝”,它并不是小浣熊本熊。猜猜哪隻是浣熊,哪隻是小熊貓,哪隻是貉?下面這個虔誠地用水洗着棉花糖的,才是小浣熊本尊,沒錯了。它是灰色的,有黑眼圈,“眼罩”橫...
2026-01-11
木薯粉粉條跟紅薯粉粉條有啥區别
木薯粉粉條跟紅薯粉粉條有啥區别
粉條、粉絲是我們餐桌上常見的食物,粉條的制作曆史甚至可以追溯到春秋戰國時期,相傳著名的龍口粉絲就是由孫膑所發明,雖無史料确實記載,但也足以看出我國的粉條曆史的悠久。粉條的種類豐富,科學興農本人最喜歡的是紅薯粉條,但最近的紅薯粉條卻因造假問題...
2026-01-11
鳄魚的眼淚思維導圖
鳄魚的眼淚思維導圖
我們為何就一口咬定鳄魚的眼淚就是虛情假意呢?畢竟在看到一個人真的傷心落淚時,我們不會稱之為海狸的淚或者鳄魚之泣。那麼原因何在?鳄魚真的是一種特别狡詐的生物嗎?credit:銳景創意幾個世紀前就盛傳鳄魚會通過眼淚誘騙獵物上鈎,随後用他們的血盆...
2026-01-11
Copyright 2023-2026 - www.tftnews.com All Rights Reserved