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

二叉树的最大深度:

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

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

算法:

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

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

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

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

调试过程:

递归法:

原因: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)。

相关推荐
Musennn14 分钟前
leetcode 15.三数之和 思路分析
算法·leetcode·职场和发展
CM莫问3 小时前
<论文>(微软)避免推荐域外物品:基于LLM的受限生成式推荐
人工智能·算法·大模型·推荐算法·受限生成
康谋自动驾驶4 小时前
康谋分享 | 自动驾驶仿真进入“标准时代”:aiSim全面对接ASAM OpenX
人工智能·科技·算法·机器学习·自动驾驶·汽车
C++ 老炮儿的技术栈4 小时前
什么是函数重载?为什么 C 不支持函数重载,而 C++能支持函数重载?
c语言·开发语言·c++·qt·算法
yychen_java5 小时前
R-tree详解
java·算法·r-tree
MarkHard1235 小时前
Leetcode (力扣)做题记录 hot100(62,64,287,108)
算法·leetcode·职场和发展
王RuaRua6 小时前
[数据结构]5. 栈-Stack
linux·数据结构·数据库·链表
一只鱼^_6 小时前
牛客练习赛138(首篇万字题解???)
数据结构·c++·算法·贪心算法·动态规划·广度优先·图搜索算法
一只码代码的章鱼6 小时前
Spring的 @Validate注解详细分析
前端·spring boot·算法
邹诗钰-电子信息工程6 小时前
嵌入式自学第二十一天(5.14)
java·开发语言·算法