首页
/
每日頭條
/
生活
/
算法的經典例題
算法的經典例題
更新时间:2026-06-11 20:15:46

算法的經典例題?給定一組不含重複元素的整數數組 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-11
對郦波講詩的評價
對郦波講詩的評價
對郦波講詩的評價?這個争論有一段時間了現在看出來,這件事的本質并不在于論郦詩的好壞,而是在于有一種争名奪利,博人眼球的勝負心在其中作怪,是一個典型的借名人之名而出名的例子這個看看事件過程即可明曉,現在小編就來說說關于對郦波講詩的評價?下面内...
2026-06-11
阿凡達2上映時間多長
阿凡達2上映時間多長
距離《阿凡達》首映已經過去了13年,全球矚目的續集《阿凡達:水之道》(以下稱《阿凡達2》)終于要和觀衆見面了,目前該片已定檔今年12月16日北美上映。《阿凡達2》仍由“卡神”詹姆斯·卡梅隆執導,薩姆·沃辛頓、佐伊·索爾達娜、西格妮·韋弗領銜...
2026-06-11
看美劇學英語推薦美劇零基礎
看美劇學英語推薦美劇零基礎
,
2026-06-11
西遊記十四回概括
西遊記十四回概括
西遊記十四回概括?劉伯欽送唐僧到兩屆山,救出了孫悟空,師徒别劉伯欽西行途中寄宿遇見六個山賊(分别是:眼看喜,耳聽怒,鼻嗅愛,舌嘗思,意見欲,身本憂代表人的六種感官享受),悟空殺死六賊,唐僧責怪悟空殺人,于是悟空撇下唐僧,接下來我們就來聊聊關...
2026-06-11
Copyright 2023-2026 - www.tftnews.com All Rights Reserved