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
相关推荐
Dr.Kun2 分钟前
【鲲码园PsychoPy】延迟折扣任务(DDT)
python·psychopy·心理学编程
coding者在努力15 分钟前
LangChain简介,最直白的介绍
人工智能·python·语言模型·langchain
癫狂的兔子32 分钟前
【Python】【机器学习】支持向量积
python·机器学习
梦想画家33 分钟前
无前端编码,解锁Langflow无限可能:自定义Python组件开发全指南
python·智能体·langflow
-Rane1 小时前
【C++】vector
开发语言·c++·算法
电饭叔1 小时前
python转换字符串介绍
开发语言·windows·python
代码栈上的思考1 小时前
滑动窗口算法实战
算法
doris82041 小时前
Python 正则表达式 re.findall()
java·python·正则表达式
Mrliu__1 小时前
Python高级技巧(六):正则表达式
开发语言·python·正则表达式
Eloudy1 小时前
直接法 读书笔记 06 第6章 LU分解
人工智能·算法·ai·hpc