LeetCode 1080. 根到叶路径上的不足节点

news2024/11/21 1:31:56

【LetMeFly】1080.根到叶路径上的不足节点

力扣题目链接:https://leetcode.cn/problems/insufficient-nodes-in-root-to-leaf-paths/

给定一棵二叉树的根 root,请你考虑它所有 从根到叶的路径:从根到任何叶的路径。(所谓一个叶子节点,就是一个没有子节点的节点)

假如通过节点 node 的每种可能的 “根-叶” 路径上值的总和全都小于给定的 limit,则该节点被称之为「不足节点」,需要被删除。

请你删除所有不足节点,并返回生成的二叉树的根。

 

示例 1:


输入:root = [1,2,3,4,-99,-99,7,8,9,-99,-99,12,13,-99,14], limit = 1

输出:[1,2,3,4,null,null,7,8,9,null,14]

示例 2:


输入:root = [5,4,8,11,null,17,4,7,1,null,null,5,3], limit = 22

输出:[5,4,8,11,null,17,4,7,null,null,null,5]

示例 3:


输入:root = [5,-6,-6], limit = 0
输出:[]

 

提示:

  1. 给定的树有 1 到 5000 个节点
  2. -10^5 <= node.val <= 10^5
  3. -10^9 <= limit <= 10^9

 

方法一:深度优先搜索DFS

首先我们将“limit”理解为“need”,意思为“路径总和还需要need这么多才能不被删除”

接着我们就可以开始递归了。递归函数“dfs(TreeNode* root, int need)”的功能是:

从root到叶节点,是否所有的路径的和都小于need。如果是,则说明root需要被删除,返回“空”;否则,返回删除过左右子节点的root。

具体怎么判断呢?

  • 如果root是叶节点,那么就看 n e e d − r o o t . v a l need - root.val needroot.val是否大于 0 0 0。如果大于0,就说明要删掉root节点;否则直接返回root节点。
  • 否则(root不是叶节点),将root的左右子替换成递归后的结果,如果左右子都空,则删掉root;否则返回修改过左右子的root。

为了方便,我们也可以直接使用题目中自带的sufficientSubset函数作为dfs函数。

  • 时间复杂度 O ( n ) O(n) O(n),其中 n n n是二叉树的节点个数
  • 空间复杂度 O ( n ) O(n) O(n)

AC代码

C++

class Solution {
public:
    TreeNode* sufficientSubset(TreeNode* root, long long limit) {
        limit -= root->val;
        if (!root->left && !root->right) {  // 叶节点
            if (limit <= 0) {
                return root;
            }
            else {
                // delete root;
                return nullptr;
            }
        }
        TreeNode* left = root->left ? sufficientSubset(root->left, limit) : nullptr;
        TreeNode* right = root->right ? sufficientSubset(root->right, limit) : nullptr;
        if (!left && !right) {
            // delete root;
            return nullptr;
        }
        else {
            root->left = left;
            root->right = right;
            return root;
        }
    }
};

Python

# from typing import Optional

# # Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right


class Solution:
    def sufficientSubset(self, root: Optional[TreeNode], limit: int) -> Optional[TreeNode]:
        limit -= root.val
        if not root.left and not root.right:
            if limit <= 0:
                return root
            else:
                return None
        left = self.sufficientSubset(root.left, limit) if root.left else None
        right = self.sufficientSubset(root.right, limit) if root.right else None
        if not left and not right:
            return None
        else:
            root.left = left
            root.right = right
            return root

同步发文于CSDN,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/130801361

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/553503.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用GPT-4.0编写量化交易策略:方法、案例与参数优化

量化策略开发&#xff0c;高质量社群&#xff0c;交易思路分享等相关内容 『正文』 ˇ 随着人工智能的发展&#xff0c;GPT-4.0已经成为量化交易策略编写的强大工具。在这篇文章中&#xff0c;我们将探讨如何使用GPT-4.0编写量化交易策略&#xff0c;并提供一个实际的案例。我…

Maven基础学习---5、其他核心概念

1、生命周期 1、作用 为了让构建过程自动化完成&#xff0c;Maven设定了三个生命周期。生命周期中的每一个环节对应构建过程中的一个操作。 2、三个生命周期 3、特点 前面三个生命周期彼此都是独立的在任何一个生命周期内部&#xff0c;执行任何一个具体环节的操作&#xff…

ElasticSearch 的DSL查询文档

一、DSL查询文档 本章目标 文本检索&#xff1a;match_all、match、multi_match精确查询&#xff1a;term、range地理坐标查询&#xff1a;geo_distance复合查询&#xff1a;function_score、bool 1. 说明 查询语法&#xff1a; GET /索引库名/_search {"query": {}…

基于C++实现房贷计算器的设计

访问【WRITE-BUG数字空间】_[内附完整源码和文档] 本次项目的要求是完成一个房贷计算器的设计&#xff0c;实现商业贷款、公积金贷款和组合贷款的利息计算三种功能。并且使用Qt或其他的界面库设计人机交互界面&#xff0c;要求界面友好方便使用。并且必须使用面向对象的思想进…

NSS周常刷密码(1)

感觉没怎么做密码,就每周上nss随便做点 稍微难点的会分析 [SWPU 2020]happy import gmpy2 from Crypto.Util.number import * import z3c 0x7a7e031f14f6b6c3292d11a41161d2491ce8bcdc67ef1baa9e e 0x872a335 #q q*p^3 128536731745208998078944182958039785532190189…

ChatGPT 4.0大升级,能替代留学中介吗?

ChatGPT4.0发布了&#xff01; 在之前轰动世界版本的基础上又有了大幅度升级&#xff0c;根据官方介绍&#xff0c;它的输入可以是文字&#xff08;上限2.5万字&#xff09;还可以是图像&#xff0c;是一个超大的多模态模型。 越来越多的人开始好奇这个东西到底能用来做什么&…

CMake Practice 学习笔记三---建立动静态库

任务&#xff1a; 建立一个静态库和动态库&#xff0c;提供HelloFunc函数供其他程序编程使用&#xff0c;HelloFunc向终端输出Hello World字符串。安装头文件与共享库。 1、准备工作 在/backup/cmake目录建立t3目录 mkdir t3建立共享库 cd t3 mkdir lib在t3目录下建立CMak…

【SCI征稿】CCF推荐|Springer旗下2区无线网络类SCI, 2个月左右录用~

一、【期刊简介】 JCR2区无线网络类SCI 【期刊概况】IF: 2.0-3.0&#xff0c;JCR2/3区&#xff0c;中科院4区&#xff1b; 【终审周期】走期刊系统&#xff0c;3个月左右录用; 【检索情况】SCI&EI双检&#xff1b; 【数据库收录年份】1967年&#xff1b; 【自引率】11…

基于最小二乘法的直线拟合原理及C++实现

“ 在数据分析的时候&#xff0c;需要尽可能地排除噪声干扰&#xff0c;以便分析出数据的本质规律。排除噪声干扰的常用手段之一是数据拟合&#xff0c;以直线、抛物线、多次曲线等为数据模型&#xff0c;对数据进行拟合。” 本文我们主要讲基于最小二乘法的直线拟合原理&#…

企业选择CRM系统的三个好处

跟随着全面放开的脚步&#xff0c;国内经济正在强势复苏&#xff0c;每家企业都在抢订单、找客户&#xff0c;想要提高企业竞争力还是要借助CRM客户管理系统&#xff0c;CRM系统客户信息管理的价值有哪些&#xff1f;从哪些方面助力企业发展。 一、高效率的管理线索 1.便捷录…

如何通过软件定义方案轻松实现卫星通信干扰测试?

GNSS信号本身的脆弱性和卫星信号传输中面临的风险一直被人们所关注着&#xff0c;例如干扰和欺骗&#xff0c;而GNSS接收设备也普遍缺乏对各种干扰的抵抗性与稳定性。根据GPS的创始架构师Brad Parkinson的说法&#xff0c;任何GNSS星座正变得越来越容易受到蓄意信号干扰或高级欺…

测试用例+自动化测试 —— 博客系统

目录 一、设计测试用例 二、自动化测试 1、导入依赖 1、登录页面 3、列表页面 4、详情页面 5、写博客页面 6、完善 三、总结 一、设计测试用例 二、自动化测试 使用selenium4 Junit5单元测试框架&#xff0c;来进行简单的自动化测试。 1、导入依赖 创建Maven项目&am…

Apache Flink 文件上传漏洞 (CVE-2020-17518)

文章目录 一、Apache Flink简介二、漏洞简介三、漏洞复现四、上传jar包getshell 一、Apache Flink简介 Apache Flink 是一个框架和分布式处理引擎&#xff0c;用于在无边界和有边界数据流上进行有状态的计算。Flink 能在所有常见集群环境中运行&#xff0c;并能以内存速度和任…

不限提问次数,免费无限制使用ChatGPT的手把手详细教程,国内最新免费使用ChatGPT教程

目录 一、使用效果 二、注册使用教程 1.打开Edge浏览器扩展 2.选择Edge浏览器外接程序 3.搜索WeTab 4.进入管理扩展 5.启用扩展 6.进入WeTab新标签页 7.打开Chat AI 8.注册 9.使用 ChatGPT是OpenAI推出的人工智能语言模型&#xff0c;能够通过理解和学习人类的语言来…

IC代理商教你如何通过壳盖辨别翻新二手芯片

老师傅会告诉你看经验看的多了&#xff0c;自然就能区分了。可经验从哪里来呢&#xff1f;ic代理商将从壳盖、定位孔和针脚三个方面来讲&#xff0c;干货满满做好笔记。 壳盖指的是芯片印制的一面&#xff0c;上面有芯片的型号和定位孔&#xff0c;全新的壳盖看着是磨砂的&…

你想要的PDF预览新方式,微信小程序绝对不容错过

前言 随着微信小程序的不断发展和变革&#xff0c;越来越多的功能被开发出来&#xff0c;其中预览 PDF 文件功能也已经成为小程序的常见应用之一。今天&#xff0c;我们将针对微信小程序预览 PDF 这一功能&#xff0c;为大家详细解析和介绍。 实现思路 在小程序界面中添加一个…

Mac苹果电脑杀毒软件CleanMyMac X

CleanMyMac X上手完全没难度。CleanMyMac X拥有非常精美的UI设计&#xff0c;左侧是功能菜单&#xff0c;各个功能板块简洁明了&#xff0c;我想对于小白用户来说上手也是没难度的。 具有强大的防御和恶意程序清除功能。CleanMyMacX不仅是一款Mac清洁软件&#xff0c;也是一款专…

c++ 11标准模板(STL) std::set(十)

定义于头文件 <set> template< class Key, class Compare std::less<Key>, class Allocator std::allocator<Key> > class set;(1)namespace pmr { template <class Key, class Compare std::less<Key>> using se…

基于html+css的图展示84

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

NÜWA:多模态预训练模型,大杀四方!(附源代码下载)

关注并星标 从此不迷路 计算机视觉研究院 ​​​ 公众号ID&#xff5c;ComputerVisionGzq 学习群&#xff5c;扫码在主页获取加入方式 论文地址&#xff1a;https://arxiv.org/abs/2111.12417 源代码&#xff1a;https:// github.com/microsoft/NUWA 计算机视觉研究院专栏 作者…