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
相关推荐
wengqidaifeng22 分钟前
探索数据结构(二):空间复杂度
c语言·开发语言·数据结构
难得的我们23 分钟前
单元测试在C++项目中的实践
开发语言·c++·算法
weixin1997010801623 分钟前
加盟网 item_search - 根据关键词获取行业列表接口对接全攻略:从入门到精通
java·python
喵手23 分钟前
Python爬虫实战:采集巨潮资讯网等上市公司公告数据,通过智能关键词匹配技术识别分红、回购、停牌等重要信息(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集巨潮资讯数据·智能匹配识别分红、回购等信息·csv导出+sqlite
Once_day24 分钟前
代码训练总结(1)算法和数据结构的框架思维
数据结构·算法
cyforkk24 分钟前
11、Java 基础硬核复习:常用类和基础API的核心逻辑与面试考点
java·python·面试
小鸡吃米…27 分钟前
机器学习 —— 数据缩放
人工智能·python·机器学习
鹿角片ljp28 分钟前
力扣125.验证回文串-双指针
数据结构·算法
夏乌_Wx29 分钟前
练题100天——DAY44:回文链表 ★★☆☆☆
数据结构
JHC00000035 分钟前
智能体造论子--简单封装大模型输出审核器
开发语言·python·机器学习