二叉树的直径
创作时间:
作者:
@小白创作中心
二叉树的直径
引用
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
}
};
热门推荐
高血压患者可以吃西红柿炒鸡蛋吗?专家解读
金线莲的种植环境介绍,每隔4-5天浇灌一次
中国第四艘航母今年上船台?12万吨+核动力+歼-50 福特级将被超越
夏日炎炎:清凉色系的穿搭指南
劳动法规中的离退休员工辞退规定及注意事项
“旌”字详解:读音、字形演变及其在古代文献中的应用
颈椎病有哪些类型?哪种最常见?哪种最严重?
蓝牙笔记本电脑重启方法详解(轻松解决蓝牙问题)
抖音视频发布热点:抓住趋势,提高内容曝光率的策略
智能客服系统:数字化转型中的客户服务革新
房租退还的“坑”:律师带你了解提前退租需知的法律常识
App适老化评测报告:十大优质应用名单发布
怎样才能把血压降下来
最近咳嗽的孩子,请看过来......
生成式AI赋能初中语文课堂教学:从理论到实践的应用指南
如何看热门标题数据库
带宽、宽带、速率、各个单位以及监控应用总结
千万别因选错指标,毁了你的A/B实验
三分钟了解欧洲历史
周邦彦:北宋婉约派代表词人之一,他的词极富音韵美
联合团队研发多功能人造皮肤——精准控制药物释放 提升创面修复质量
营养师考试科目有哪些具体要求?
快千万亿倍!中国科学家再破世界纪录
成都高新区国土空间总体规划获批,擘画2035年发展蓝图
爆款文案标题写作技巧与示例
如何通过期货回测优化交易策略?回测对交易决策有何意义?
吞噬鳗:深海中的神秘“巨口怪”
Excel表格中文本对齐功能详解:从基础到进阶
Excel文字前后对齐的多种方法
睡不著怎麼辦?6大失眠因子、7大解決方法與飲食方式大公開