LeetCode543题:二叉树的直径(python3)

代码思路:

先递归调用左儿子和右儿子求得它们为根的子树的深度 L和 R ,则该节点为根的子树的深度即为max(L,R)+1。该节点的 dnode值为L+R+1

递归搜索每个节点并设一个全局变量 ans记录 dnode的最大值,最后返回 ans-1 即为树的直径。

python 复制代码
# 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 diameterOfBinaryTree(self, root: Optional[TreeNode]) -> int:
        self.ans = 1
        def depth(node):
            # 访问到空节点了,返回0
            if not node: 
                return 0 
            # 左儿子为根的子树的深度
            L = depth(node.left) 
            # 右儿子为根的子树的深度
            R = depth(node.right)
            # 计算d_node即L+R+1 并更新ans
            self.ans = max(self.ans,L+R+1)
            # 返回该节点为根的子树的深度
            return max(L,R)+1 
        depth(root)
        return self.ans-1
相关推荐
追随者永远是胜利者6 小时前
(LeetCode-Hot100)20. 有效的括号
java·算法·leetcode·职场和发展·go
清水白石0086 小时前
Python 纯函数编程:从理念到实战的完整指南
开发语言·python
掘根6 小时前
【C++STL】平衡二叉树(AVL树)
开发语言·数据结构·c++
twilight_4696 小时前
机器学习与模式识别——机器学习中的搜索算法
人工智能·python·机器学习
瓦特what?6 小时前
快 速 排 序
数据结构·算法·排序算法
niuniudengdeng7 小时前
基于时序上下文编码的端到端无文本依赖语音分词模型
人工智能·数学·算法·概率论
hetao17338377 小时前
2026-02-13~16 hetao1733837 的刷题记录
c++·算法
Jia ming7 小时前
《智能法官软件项目》—罪名初判模块
python·教学·案例·智能法官
Jia ming7 小时前
《智能法官软件项目》—法律文书生成模块
python·教学·案例·智能法官软件
曦月逸霜7 小时前
Python数据分析——个人笔记(持续更新中~)
python