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;
    }
};
相关推荐
昵称小白4 小时前
复杂度分析方法
算法
科研前沿4 小时前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
学涯乐码堂主6 小时前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
Tutankaaa6 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073217 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee9 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99909 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5059 小时前
深入理解主成分分析(PCA)
算法
apollowing9 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F9 小时前
最小堆定时器
数据结构·算法