Leetcode543. 二叉树的直径(HOT100)

链接

代码:

cpp 复制代码
class Solution {
public:
    int res = 0;
    int diameterOfBinaryTree(TreeNode* root) {
        dfs(root);
        return res;
    }
    int dfs(TreeNode* root){
        if(!root)return 0;
        int left = dfs(root->left),right = dfs(root->right);
        res = max(res,left+right);
        return max(left,right)+1;
    }
};

题解:

要求最大直径,其实有点类似于深度,以root节点为例,直径最大就是左子树的3+右子树的4,答案就是7。

对于二叉树来说,我们使用dfs遍历所有点,自下而上,把子节点的值返回给父节点,最终算出整个树的最大直径。

还有一个注意的点:给上一层返回的时候应该返回多少?当然是你往左走(left的值)和往右走(right)的值的最大值,然后再加上1--------上一层来到当前节点,也需要走一步。

相关推荐
烁3471 小时前
每日一题(小白)暴力娱乐篇20
java·开发语言·算法·排序算法·娱乐
写个博客1 小时前
代码随想录算法训练营第十三天
算法
满天星83035771 小时前
文件的操作
数据结构·c++·算法
heyCHEEMS1 小时前
01背包 Java
java·算法·深度优先
雾月557 小时前
LeetCode 941 有效的山脉数组
java·开发语言·数据结构·算法·leetcode·职场和发展
uhakadotcom8 小时前
归因工具:了解国内外顶级产品
算法·面试·github
小羊在奋斗10 小时前
【多源BFS】01 矩阵 / 飞地的数量 / 地图中的最高点 / 地图分析 / 腐烂的苹果
算法·矩阵·宽度优先
WG_1710 小时前
图论:多源最短路
数据结构·c++·算法
一只小透明啊啊啊啊10 小时前
【leetcode 100】贪心Java版本
java·算法·leetcode
白白糖11 小时前
组合与括号生成(回溯)
python·算法·力扣