首页
/
每日頭條
/
生活
/
算法的經典例題
算法的經典例題
更新时间:2026-03-07 12:24:18

算法的經典例題?給定一組不含重複元素的整數數組 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
推荐阅读
武漢步行街店鋪現狀
武漢步行街店鋪現狀
品牌升級中的永旺夢樂城武漢金銀潭店撰文|MrK支持|Jess在本專欄的第一篇文章中,L君分享了當年運營商場微信公衆号時遇到的一件尬事,也比較慶幸當時未造成太大的影響。今年4月中旬,L君也碰到了一件武漢同行的類似案例。因為所處時期的特殊性,本...
2026-03-07
相親要婚前買房嗎
相親要婚前買房嗎
來源:義烏十八腔有網友在十八腔app發帖:我的好閨蜜,26歲,顔值身材7分,年初在父母的資助下再加上自己的存款,買了套小高層,兩室一廳,貸款八十萬。有房之後看得出來走路都帶風,更加自信了。可是最近相了幾次親,都被拒絕了,有房無貸的男的表示本...
2026-03-07
适合農村老人用的東西
适合農村老人用的東西
“簸箕”(音讀[bòji])對于農村的小夥伴們來說肯定不陌生。以前時常看見老人們在自家的庭院裡揚米,以去除空殼或小石頭等雜物。在農村,簸箕是家庭生活的必備之物,一張簸箕用得愛惜點兒可以用好幾輩兒,最少也可用十幾年。現在,種地的農民越來越少,...
2026-03-07
腎功能衰竭的早期症狀
腎功能衰竭的早期症狀
腎功能衰竭的早期症狀?腎衰竭分為急性和慢性兩種,急性腎衰竭主要表現為少尿或者無尿,尿素氮和血肌酐也很快升高,嚴重的還合并心力衰竭、血壓的升高慢性腎功能衰竭前期患者可能會感覺到腰酸、乏力、夜尿增多、食欲減退等等症狀而到後期上述症狀會加重,可能...
2026-03-07
人與人之間的緣分需要珍惜
人與人之間的緣分需要珍惜
人與人之間的緣分需要珍惜?人生一世,從呱呱墜地開始,就逐漸建立起越來越多、紛繁複雜的人際關系先父母、祖父母、外祖父母…然後随着年齡的增長,人際關系由親情關系快速向社會擴展,同學、戰友、同事、朋友應運而生在這些關系中,表面是親情、友情和愛情的...
2026-03-07
Copyright 2023-2026 - www.tftnews.com All Rights Reserved