当前位置: 首页 > news >正文

力扣78 子集

给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的
子集(幂集)。
解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
示例 1:
输入:nums = [1,2,3]
输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

数据结构:递归栈
算法:按数组顺序进行递归,每次的结果都保存下来,然后进行回溯继续递归
本题不难,但是长时间没做和全排列搞混淆了,这里不需要判断当前数是否在本次递归中是否使用,因为每次进递归都是从上次数的下一个进的。

class Solution {// private int[] flag;List<List<Integer>> list = new ArrayList<>();List<Integer> list1 = new ArrayList<>();public List<List<Integer>> subsets(int[] nums) {// flag = new int[nums.length];dfs(nums,0);return list;}void dfs(int[] nums,int start){list.add(new ArrayList(list1));if(start >= nums.length)return;for(int i = start; i < nums.length; i++){list1.add(nums[i]);dfs(nums,i+1);list1.remove(list1.size()-1);}       }
}
http://www.lryc.cn/news/382365.html

相关文章:

  • C语言从头学24——函数原型
  • Vue中使用ElementUI组件Form组件的校验validate
  • PostgreSQL性能优化之分区表 #PG培训
  • SAPUI5基础知识9 - JSON Module与数据绑定
  • 解决vue3使用ref 获取不到子组件属性问题
  • 使用STL容器还是Qt容器?
  • Android 2ndBLE的实现
  • 常见硬件工程师面试题(二)
  • java构造方法的重载
  • webpack 压缩图片
  • JAVA每日作业day6.24
  • 鸿蒙开发系统基础能力:【@ohos.hiTraceChain (分布式跟踪)】
  • .git目录解读
  • 如何在Java中处理InterruptedException异常?
  • 深入解读Netty中的NIO:原理、架构与实现详解
  • Vim和Nano简介
  • mysql的information_schema浅析
  • 力扣爆刷第153天之TOP100五连刷26-30(接雨水、环形链表、最长上升子序列)
  • 【Linux】—Apache Hive 安装部署
  • 组装盒示范程序
  • 推荐一款AI修图工具,支持AI去水印,AI重绘,AI抠图...
  • 2024广东省职业技能大赛云计算赛项实战——容器化部署Nginx
  • 压缩pdf文件大小在线,在线免费压缩pdf
  • 薄冰英语语法学习--名词1
  • oracle12c到19c adg搭建(六)切换后12c备库服务器安装19c软件在19c主库升级数据字典后尝试同步
  • Scope XY Project的使用
  • Pytorch Geometric(PyG)入门
  • 大模型KV Cache节省神器MLA学习笔记(包含推理时的矩阵吸收分析)
  • 项目中eventbus和rabbitmq配置后,不起作用
  • 文库小程序搭建部署:实现资源共享正向反馈