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
相关推荐
CoderYanger3 分钟前
递归、搜索与回溯-综合练习:19.目标和
java·算法·leetcode·1024程序员节
mit6.8243 分钟前
dfs|mask^翻转
算法
量化Mike15 分钟前
【python报错】解决卸载Python时报错问题:No Python installation was detected
开发语言·python
SKYDROID云卓小助手20 分钟前
三轴云台之控制协同技术
服务器·网络·图像处理·人工智能·算法
The Last.H27 分钟前
Educational Codeforces Round 185 (Rated for Div. 2)A-C
c语言·c++·算法
2501_9417987327 分钟前
Python高性能网络爬虫实战:异步IO与多线程结合代码解析
开发语言·python
java1234_小锋28 分钟前
基于Python深度学习的车辆车牌识别系统(PyTorch2卷积神经网络CNN+OpenCV4实现)视频教程 - 车牌矩阵定位
python·深度学习·cnn·车牌识别
linzeyang41 分钟前
Advent of Code 2025 挑战全手写代码 Day 1 - 秘密入口
python·github
客梦1 小时前
数据结构基本知识
数据结构
阿郎_20111 小时前
python自动化脚本-下载小说
python·selenium·网络爬虫