二叉树的直径
创作时间:
作者:
@小白创作中心
二叉树的直径
引用
CSDN
1.
https://blog.csdn.net/2302_80190174/article/details/140110619
给你一棵二叉树的根节点,返回该树的 直径 。
二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点。两节点之间路径的 长度 由它们之间边数表示。
图中二叉树的直径也就是三条红线。
深度优先搜索
首先我们知道一条路径的长度为该路径经过的节点数减一,所以求直径(即求路径长度的最大值)等效于求路径经过节点数的最大值减一。
而任意一条路径均可以被看作由某个节点为起点,从其左儿子和右儿子向下遍历的路径拼接得到。
如图我们可以知道路径 [ 4, 2, 1] 可以被看作以 1 为起点,从其左儿子向下遍历的路径 [1, 2, 4] 和从其右儿子向下遍历的路径 [1 , 3] 拼接得到。
假设我们知道对于该节点的左儿子向下遍历经过最多的节点数 L (即以左儿子为根的子树的深度) 和其右儿子向下遍历经过最多的节点数 R (即以右儿子为根的子树的深度),那么以该节点为起点的路径经过节点数的最大值即为 L+R+1 。
最后的算法流程为:我们定义一个递归函数 depth(node) ,函数返回该节点为根的子树的深度。先递归调用左儿子和右儿子求得它们为根的子树的深度 L 和 R ,则该节点为根的子树的深度即为:max( L , R ) + 1 。
class Solution {
int ret;
int depth(TreeNode* root){
if (root == NULL) {
return 0; // 空节点返回0
}
int L = depth(root->left); // 左子树的深度
int R = depth(root->right); // 右子树的深度
ret = max(ret, L + R + 1); // 计算即L+R+1 并更新ret
return max(L, R) + 1; // 返回该节点为根的子树的深度
}
public:
int diameterOfBinaryTree(TreeNode* root) {
ret = 1;
depth(root);
return ret - 1;//root为空时,返回1-1即0
}
};
热门推荐
脑电波操控未来:科技与人类思维的革命
黄霑:其实我都会抄歌……解密霑叔词曲背后的故事
坐火车什么东西不能带?这些违禁品你需要知道!
蜀汉政权内部的颜色革命,统治阶层由荆州集团变成东州集团
光伏电站监控系统组成全解析
天秤座难过时该怎么安慰 十二星座中对天秤座最好的四个星座
怎么对付天秤座最好
镁在氮气中燃烧及二氧化硫吸收实验详解
明年各地将继续增加保障性住房供给,城中村改造如何影响房价?
又见平遥:血脉传承与心灵史诗
晶体管单管放大电路三种基本接法详解
4050显卡还能用几年?性能表现与未来展望
在希望的田野上丨农忙尽显“科技范儿” 智能设备助力春耕备耕
开车这么多年,可“1升汽油”等于多少斤,你们知道么?
足金秒变金包银,电商黄金市场假证书泛滥,无需寄样10余元可定制
25首经典怀古诗词,荡气回肠,穿透古今
古代宫女12岁前进宫,25岁后出宫,她们出宫后如何生活呢?
数据库设计中如何实现对历史数据的有效管理
充电宝长时间不使用应该如何保存
Web端如何获取手机的唯一标识
门槛石尺寸要求及材料种类安装注意事项
Excel下拉列表选择数据源的多种方法
沥青的生产过程是怎样的?了解这些过程对环境保护有何意义?
“新国风”与“文化魂” ——动画电影《落凡尘》的启示
“份量”十足 “新”意满满 长春北湖未来科学城明确未来三年发展路径
助理工程师职称评定申请指南
新生儿打喷嚏的原因及缓解方法
服药时的用水有讲究,选对疗效能倍增
零基础如何过英语四级
高血压患者不宜喝什么茶