39.二叉树的直径

1.题目描述

求二叉树最远的两个节点的长度

2.题解代码

结合二叉树最大深度那一题一起看,可以知道这一题就是多了一句代码,具体见代码,脑子里一定要有basecase的情况,自己动手画一画

cpp 复制代码
class Solution {
    int ans;
public:

    int diameterOfBinaryTree(TreeNode* root) {
        ans = 0;//维护一个整个递归过程中都实时记录最大值的ans
        dfs(root);
        return ans;
    }
    int dfs(TreeNode* root){
        if(root==NULL){
            return 0;
        }
        int left = dfs(root->left);
        int right = dfs(root->right);

        //如果没有以下一句则就表示求二叉树的最大深度,细品,知识多了个参数记录最大的路径罢了
        ans = max(left+right,ans);

        return max(left,right)+1;
    }
};
相关推荐
历程里程碑36 分钟前
Linux22 文件系统
linux·运维·c语言·开发语言·数据结构·c++·算法
YGGP2 小时前
【Golang】LeetCode 128. 最长连续序列
leetcode
你撅嘴真丑8 小时前
第九章-数字三角形
算法
uesowys8 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder8 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮8 小时前
AI 视觉连载1:像素
算法
智驱力人工智能9 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥9 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风9 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風10 小时前
8.1 PFH&&FPFH
图像处理·算法