6.6二叉树的最大深度(LC104-E)、N叉树的最大深度(LC559-E)

news2024/11/24 14:26:42

二叉树的最大深度:

二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。

二叉树的最大深度=二叉树的高度

算法:

这道题既可以求深度,也可以直接求高度。不过高度和深度用的遍历方式不同。

二叉树写代码之前要确定遍历顺序!

求高度(从下往上求高度):后序遍历(左右中)。先求左右孩子的最大高度(左右),再加上根节点的高度(中)。

求深度:前序遍历(中左右)。

调试过程:

递归法:

原因:node可能为空,我没判断node非空

正确代码:

# 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 maxDepth(self, root: Optional[TreeNode]) -> int:
        if root == None:
            return 0
        else:
            return self.getdepth(root)

    def getdepth(self,node:Optional[TreeNode])-> int:
        if node == None:
            return 0
        else:
            #左右
            leftheight = self.getdepth(node.left)
            rightheight = self.getdepth(node.right)
            #中
            depth = 1+max(leftheight,rightheight)
            return depth

时间空间复杂度:

  • 时间复杂度: 该代码使用递归方法计算二叉树的最大深度。在最坏的情况下,当二叉树完全不平衡并且类似于链表时,代码将恰好访问每个节点一次。因此,代码的时间复杂度为O(n),其中n是二叉树中的节点数。
  • 空间复杂度: 代码的空间复杂度由二叉树的最大深度决定。在最坏的情况下,当二叉树完全不平衡并且类似于链表时,最大深度(高度)将等于树中的节点数。因此,代码的空间复杂度为O(n),其中n是二叉树中的节点数。
  • 总体而言,该代码的时间复杂度为O(n),空间复杂度为O(n)。

N叉树的最大深度:

算法:

求高度(从下往上求高度):先求根节点所有子树的最大高度,再加上根节点的高度。

N叉树的定义(要会写!):

class Node:
    def __init__(self, val=None, children=None):
        self.val = val
#children就是根节点的孩子
        self.children = children

调试过程:

递归法:

原因:

错误是在 `for` 循环中尝试使用变量 `depth`,但在循环之前没有初始化该变量。这导致在 `return depth` 语句处引发了 `UnboundLocalError` 错误。

要解决这个问题,可以在 `maxDepth` 方法之前初始化 `depth` 变量

正确代码:

"""
# Definition for a Node.
class Node:
    def __init__(self, val=None, children=None):
        self.val = val
        self.children = children
"""
class Solution:
    def maxDepth(self, root: 'Node') -> int:
        if root == None:
            return 0
        else:
            depth = 1
            for children in root.children:
                depth = max(depth, self.maxDepth(children)+1)
            return depth
        

时间空间复杂度:

时间复杂度: 修复后的代码使用递归方法计算 N 叉树的最大深度。在最坏的情况下,当 N 叉树完全不平衡时,代码将访问每个节点一次。因此,时间复杂度为 O(n),其中 n 是 N 叉树中的节点数。

空间复杂度: 修复后的代码的空间复杂度由递归调用栈的深度决定。在最坏的情况下,当 N 叉树完全不平衡时,递归调用栈的深度将等于树的高度。因此,空间复杂度为 O(h),其中 h 是 N 叉树的高度。

总体而言,代码的时间复杂度为 O(n),空间复杂度为 O(h)。

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

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

相关文章

基于Java实现的轻量级私有云平台,让企业拥有自己的云平台

一、开源项目简介 KVM Cloud 是一款基于Java实现的轻量级私有云平台,旨在帮助中小企业快速实现计算、存储、网络等资源的管理,让企业拥有自己的云平台。 二、开源协议 使用Apache-2.0开源协议 三、界面展示 四、功能概述 KVM Cloud 是一款基于Java实…

JAVA基础语法编程详解---三目运算符

6.判断体重指数 题目描述 - 描述 体重指数 体重 (kg) / ( 身高 (m) 身高 (m) ),小于18.5属于偏瘦,介于18.5和20.9之间(左闭右开)属于苗条,介于20.9和24.9之间(左闭右闭)属于适中,…

python入口文件方便在其它目录也能执行

dir_path os.path.dirname(os.path.realpath(__file__)) parent_dir_path os.path.abspath(os.path.join(dir_path, os.pardir)) sys.path.insert(0, parent_dir_path)

优秀智慧园区案例 - 新华三未来工厂制造园,园区业务创新及零碳升级

目录 一、新华三未来工厂制造园建设背景 二、未来工厂制造园总体设计思路 三、未来工厂制造园建设内容 四、关键技术及创新点 五、应用效益与推广 关键词:智慧园区解决方案,智慧园区建设总体方案,智慧园区建设规划方案,智慧园…

J. Chem. Theory Comput. | AI驱动的柔性蛋白-小分子复合物建模

今天为大家介绍的是来自陈语谦教授团队发表在Journal of Chemical Theory and Computation的论文,“Equivariant Flexible Modeling of the Protein−Ligand Binding Pose with Geometric Deep Learning”,博士生董铁君为第一作者。该文提出了一种新的AI…

【nlp】2.2 传统RNN模型

传统RNN模型 1 传统RNN模型1.1 RNN结构分析1.2 使用Pytorch构建RNN模型1.3 传统RNN优缺点1 传统RNN模型 1.1 RNN结构分析 结构解释图: 内部结构分析: 我们把目光集中在中间的方块部分, 它的输入有两部分, 分别是h(t-1)以及x(t), 代表上一时间步的隐层输出, 以及此时间步的…

tcpdump wireshark简单使用

tcpdump工作原理 tcpdump 是 Linux 系统中非常有用的网络工具,运行在用户态,本质上是通过调用 libpcap 库的各种 api 来实现数据包的抓取功能,利用内核中的 AF_PACKET 套接字,抓取网络接口中传输的网络包。查 看 tcpdump 的 手册…

「Verilog学习笔记」用优先编码器①实现键盘编码电路

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网 分析 用此编码器实现键盘的编码电路。 注意:编码器的输出是低电平有效,而键盘编码电路输出的是正常的8421BCD码,是高电平有效。因此将编…

优思学院:SPC控制线为什么是±3西格玛?

如果你曾是初次接触SPC控制图而有充满好奇心的质量工程师,那么你一定有一个疑问,就是SPC控制线为什么是3西格玛? 在开始深入讨论之前,让我们先了解一些控制图的基本概念。控制图通常有控制上限(UCL)和控制…

【数据结构】经典单链表OJ题!!

学习完单链表,习题就成了最好的巩固方式 目录 1.链表分割:思路:代码实现: 2.随机链表的复制:思路1:代码实现:思路2:代码实现: 3.环形链表:3.1环形链表1:思路:代码实现: 3…

VS设置--查看引用库源代码

1.工具-->选项-->文本编译器-->C#-->高级-->勾选支持导航到反编译源(试验)

Java项目开发:基于Springboot+vue口腔牙科诊所管理系统

项目介绍 本选题则旨在通过标签分类管理等方式,实现管理员:首页、个人中心、会员管理、病例就诊信息管理、牙齿保健产品管理、复查提醒管理、预约挂号管理、药品信息管理、留言板管理、系统管理、订单管理,会员;首页、个人中心、…

Mozilla 面向基于 Debian 的 Linux 发行版

导读Mozilla 公司今天发布新闻稿,表示面向 Debian、Ubuntu 和 Linux Mint 等基于 Debian 的发行版,推出了.deb 格式的 Firefox Nightly 浏览器安装包,便于用户在上述发行版中更轻松地安装。 本次更新的亮点之一在于采用 APT 存储库&#xff0…

【机器学习基础】机器学习的基本术语

🚀个人主页:为梦而生~ 关注我一起学习吧! 💡专栏:机器学习 欢迎订阅!后面的内容会越来越有意思~ 💡往期推荐: 【机器学习基础】机器学习入门(1) 【机器学习基…

界面控件DevExpress WPF Splash Screen,让应用启动画面更酷炫!

DevExpress WPF的Splash Screen组件可以为应用程序创建十分酷炫的启动屏幕,提高用户在漫长的启动操作期间的体验! P.S:DevExpress WPF拥有120个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress …

(八)Spring源码解析:Spring MVC

一、Servlet及上下文的初始化 1.1> DispatcherServlet的初始化 对于Spring MVC来说,最核心的一个类就是DispatcherServlet,它负责请求的行为流转。那么在Servlet的初始化阶段,会调用init()方法进行初始化操作,在DispatcherSe…

刚刚!奥特曼终于透露了GPT-5的最新消息!

原 创作者 | Tscom、王二狗 大爆料!OpenAI被实锤正在研发GPT-5! 还是OpenAI的CEO Sam Altman 亲口证实的。 今日,奥特曼接受《金融时报》的采访,透露了很多OpenAI的下一步计划,二狗帮大家整理成以下10个要点&#x…

实现定时巡检接口,测试不通过时自动发邮件

背景是这样的:最近组织架构调整,我们这个团队部分人员调入到了另外的业务组,因此她之前负责的业务需要交接给我们。 其中一个是接口每日监测,之前这个同事的做法是每天去手动点下按钮来跑接口测试,然后看一眼接口测试…

这 11 个 for 循环优化你得会

日常开发中,经常会遇到一些循环耗时计算的操作,一般也都会采用 for 循环来处理,for 作为编程入门基础,主要是处理重复的计算操作,虽然简单好用,但在写法上也有很多的考究,如果处理不好&#xff…