news 2026/5/30 1:22:53

day153—回溯—子集(LeetCode-78)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day153—回溯—子集(LeetCode-78)

题目描述

给你一个整数数组nums,数组中的元素互不相同。返回该数组所有可能的子集(幂集)。

解集不能包含重复的子集。你可以按任意顺序返回解集。

示例 1:

输入:nums = [1,2,3]输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

示例 2:

输入:nums = [0]输出:[[],[0]]

提示:

  • 1 <= nums.length <= 10
  • -10 <= nums[i] <= 10
  • nums中的所有元素互不相同

解决方案:

这段代码的核心功能是生成一个数组的所有子集(包括空集和数组本身),采用「回溯 + 递归」的思路实现,只是把 “先不选、后选” 的顺序换成了 “先选、后不选”,最终效果完全一致。下面用简洁的语言解释整体逻辑:

核心逻辑

  1. 成员变量作用

    • t:临时数组,用于存储当前正在构造的子集(相当于 “路径”);
    • ans:最终结果数组,存储所有生成的子集。
  2. 递归函数dfs逻辑

    • 参数curr:表示当前处理到数组nums的第curr个元素;
    • 终止条件:当curr == nums.size()时,说明所有元素都处理完毕,此时t就是一个完整的子集,将其加入ans后返回;
    • 核心流程(先选后不选):①选当前元素:把nums[curr]加入临时数组t,递归处理下一个元素(curr+1);递归返回后,执行t.pop_back()恢复现场(删掉刚加入的元素,避免影响后续选择);②不选当前元素:直接递归处理下一个元素(curr+1),不对t做任何修改。
  3. 主函数subsets

    • 从第 0 个元素开始调用dfs,启动递归过程;
    • 最终返回存储了所有子集的ans

关键特点

  • 逻辑等价性:和你之前看到的 “先不选、后选” 版本功能完全一致,只是选择顺序相反,最终生成的子集顺序会略有不同(比如nums=[1,2]会生成[[1,2],[1],[2],[]],而非[[],[2],[1],[1,2]]),但都是完整的子集集合;
  • 核心思想:通过 “选(修改t后递归)+ 不选(直接递归)” 的组合,遍历所有可能的元素组合,pop_back是回溯的关键,用于恢复临时数组的状态,保证不同选择分支互不干扰。

总结

  1. 核心思路:递归遍历每个元素,对每个元素执行 “选(加入临时数组)→ 递归 → 恢复 → 不选(直接递归)” 的操作;
  2. 关键操作:t.push_back()(选元素)和t.pop_back()(恢复现场)是实现回溯的核心;
  3. 最终效果:通过递归覆盖所有元素的 “选 / 不选” 组合,最终收集到数组的全部子集。

函数源码:

class Solution { public: vector<int> t; vector<vector<int>> ans; void dfs(int curr,vector<int>& nums){ if(curr==nums.size()){ ans.push_back(t); return ; } t.push_back(nums[curr]); dfs(curr+1,nums); t.pop_back(); dfs(curr+1,nums); } vector<vector<int>> subsets(vector<int>& nums) { dfs(0,nums); return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 13:16:54

iOS 应用加固软件怎么选,从源码到IPA方案选择

第一次认真研究 iOS 应用加固软件&#xff0c;其实不是为了安全体系建设&#xff0c;而是遇到了一个很现实的问题&#xff1a; 项目已经进入维护期&#xff0c;版本节奏固定&#xff0c;但业务方突然提出最近有被拆包的风险&#xff0c;希望补一层保护。 当时团队里并没有现成方…

作者头像 李华
网站建设 2026/5/28 23:02:39

AI 写代码越快越危险?破解“高产低质”困局,这一步至关重要

一、 软件开发的核心命题&#xff1a;建立正反馈系统软件开发绕不开三大核心困境&#xff1a; 闭门研发缺反馈、功能跑偏难修正&#xff1b; 独自攻坚易内耗&#xff0c;重复造轮耗精力&#xff1b; 价值难显缺认可&#xff0c;能力成长无动力&#xff0c;如同孤身爬山&#xf…

作者头像 李华
网站建设 2026/5/28 22:26:48

【优化求解】基于粒子群优化的自动相机布放问题的Matlab代码

✅作者简介&#xff1a;热爱数据处理、建模、算法设计的Matlab仿真开发者。&#x1f34e;更多Matlab代码及仿真咨询内容点击 &#x1f517;&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知。&#x1f525; 内容介绍本研究聚焦于自动相机布放的全局优化…

作者头像 李华
网站建设 2026/5/28 22:31:40

2026年的AI发展趋势是什么?

2026年的AI发展趋势将延续当前技术演进的核心逻辑&#xff08;如大模型、多模态、生成式AI&#xff09;&#xff0c;同时在效率、场景渗透、跨学科融合及伦理规范等方面迎来关键突破。以下是基于当前技术路线和行业动态的十大趋势预测&#xff1a;1. 大模型向“高效化专业化”演…

作者头像 李华
网站建设 2026/5/28 18:14:23

深度测评本科生必备9款AI论文软件:开题报告文献综述全搞定

深度测评本科生必备9款AI论文软件&#xff1a;开题报告文献综述全搞定 学术写作工具测评&#xff1a;为何需要一份权威榜单 在当前高校教育日益重视科研能力的背景下&#xff0c;本科生在论文写作过程中面临诸多挑战。从开题报告到文献综述&#xff0c;再到最终的论文撰写&am…

作者头像 李华