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

【LeetCode 刷题】回溯算法-子集问题

此博客为《代码随想录》二叉树章节的学习笔记,主要内容为回溯算法子集问题相关的题目解析。

文章目录

  • 78.子集
  • 90.子集II

78.子集

题目链接

class Solution:def subsets(self, nums: List[int]) -> List[List[int]]:res, path = [], []def dfs(start: int) -> None:res.append(path.copy())for i in range(start, len(nums)):path.append(nums[i])dfs(i + 1)path.pop()dfs(0)return res
  • 组合和分割问题都是收集树的叶子结点,而子集问题要收集树的所有节点
  • 因此不需要额外添加判断,进入递归函数即收集答案

90.子集II

题目链接

class Solution:def subsetsWithDup(self, nums: List[int]) -> List[List[int]]:res, path = [], []nums.sort()def dfs(start: int) -> None:res.append(path.copy())for i in range(start, len(nums)):if i > start and nums[i] == nums[i-1]:continuepath.append(nums[i])dfs(i + 1)path.pop()dfs(0)return res
  • 相较于上题,此题输入集合中可能存在相同元素,但结果列表中不能有相同的子集
  • 添加排序,以及树层的去重
http://www.lryc.cn/news/530541.html

相关文章:

  • OpenCV 版本不兼容导致的问题
  • 低成本、高附加值,具有较强的可扩展性和流通便利性的行业
  • DirectShow过滤器开发-读视频文件过滤器(再写)
  • 代码练习2.3
  • 基于 Redis GEO 实现条件分页查询用户附近的场馆列表
  • 【大数据技术】案例01:词频统计样例(hadoop+mapreduce+yarn)
  • Selenium 使用指南:从入门到精通
  • 笔试-排列组合
  • Java序列化详解
  • ChatGPT与GPT的区别与联系
  • MySQL入门 – CRUD基本操作
  • Redis背景介绍
  • PPT演示设置:插入音频同步切换播放时长计算
  • DIFY源码解析
  • [权限提升] Wdinwos 提权 维持 — 系统错误配置提权 - Trusted Service Paths 提权
  • 【算法】回溯算法专题② ——组合型回溯 + 剪枝 python
  • LeetCode:121.买卖股票的最佳时机1
  • pytorch生成对抗网络
  • Visual Studio Code应用本地部署的deepseek
  • 用 HTML、CSS 和 JavaScript 实现抽奖转盘效果
  • Skewer v0.2.2安装与使用-生信工具43
  • C语言:链表排序与插入的实现
  • 【Elasticsearch】doc_values 可以用于查询操作
  • 深度学习深度解析:从基础到前沿
  • JVM的GC详解
  • 【开源免费】基于Vue和SpringBoot的校园网上店铺系统(附论文)
  • 测压表压力表计量表针头针尾检测数据集VOC+YOLO格式4862张4类别
  • Vue 3 30天精进之旅:Day 12 - 异步操作
  • 【网络】3.HTTP(讲解HTTP协议和写HTTP服务)
  • [paddle] 矩阵相关的指标