高频编程考题:二叉树的直径(简单)
创作时间:
作者:
@小白创作中心
高频编程考题:二叉树的直径(简单)
引用
CSDN
1.
https://m.blog.csdn.net/LFY5678/article/details/142700067
题目描述
给你一棵二叉树的根节点,返回该树的 直径 。
二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root
。
两节点之间路径的 长度 由它们之间边数表示。
示例 1:
输入: root = [1,2,3,4,5]
输出: 3
解释: 3 ,取路径 [4,2,1,3] 或 [5,2,1,3] 的长度。
示例 2:
输入: root = [1,2]
输出: 1
提示:
- 树中节点数目在范围
[1, 104]
内 -100 <= Node.val <= 100
解题思路
要找到二叉树的直径,我们需要找到树中任意两个节点之间的最长路径。这个路径的长度由路径中的边数决定,而不是节点数,可以使用深度优先搜索(DFS)的方法:
- 定义直径 :直径是树中两个节点之间最长的路径长度。这个路径可能会经过树的根节点,也可能不会。
- DFS 计算深度 :
- 使用 DFS 递归遍历树中的每个节点,同时计算每个节点的左右子树的深度;
- 对于每个节点,计算通过该节点的最长路径长度,即左右子树深度之和;
- 更新全局变量
maxDiameter
以记录当前最大直径。
- 计算节点的深度 :通过递归计算每个节点的左右子树的深度,返回节点的最大深度。
复杂度分析
时间复杂度
- 计算每个节点的深度 :对于树中的每个节点,我们都需要递归地计算其左右子树的深度。每个节点的处理(即计算其左右子树深度和更新最大直径)只需要常数时间。
- 总时间复杂度 :由于每个节点在 DFS 遍历过程中被访问一次,所以时间复杂度是 O(N) ,其中 N 是树中节点的总数。
空间复杂度
- 递归栈的空间 :由于使用了递归 DFS 方法,递归栈的最大深度等于树的高度。对于最坏情况(例如链式树结构),树的高度可能达到 N(节点数),此时递归栈的空间复杂度为 O(N) 。对于平衡树,递归栈的深度是树的高度,即 O(log N) 。
- 额外空间 :除了递归栈外,额外使用的空间主要是
maxDiameter
变量,空间复杂度为 O(1) 。
因此,整体的空间复杂度主要由递归栈的深度决定,对于最坏情况下是 O(N) ,而对于平衡树是 O(log N) 。
代码实现
package org.zyf.javabasic.letcode.hot100.tree;
import org.zyf.javabasic.letcode.tree.base.TreeNode;
/**
* @program: zyfboot-javabasic
* @description: 二叉树的直径(简单)
* @author: zhangyanfeng
* @create: 2024-08-22 11:23
**/
public class DiameterOfBinaryTreeSolution {
private int maxDiameter = 0; // 记录最大直径
public int diameterOfBinaryTree(TreeNode root) {
calculateDepth(root);
return maxDiameter;
}
// 计算树的深度并更新最大直径
private int calculateDepth(TreeNode node) {
if (node == null) {
return 0;
}
// 递归计算左右子树的深度
int leftDepth = calculateDepth(node.left);
int rightDepth = calculateDepth(node.right);
// 更新最大直径
maxDiameter = Math.max(maxDiameter, leftDepth + rightDepth);
// 返回当前节点的深度
return Math.max(leftDepth, rightDepth) + 1;
}
public static void main(String[] args) {
DiameterOfBinaryTreeSolution solution = new DiameterOfBinaryTreeSolution();
// 示例 1
TreeNode root1 = new TreeNode(1);
root1.left = new TreeNode(2);
root1.right = new TreeNode(3);
root1.left.left = new TreeNode(4);
root1.left.right = new TreeNode(5);
System.out.println("Example 1: " + solution.diameterOfBinaryTree(root1)); // 输出: 3
// 示例 2
TreeNode root2 = new TreeNode(1);
root2.left = new TreeNode(2);
System.out.println("Example 2: " + solution.diameterOfBinaryTree(root2)); // 输出: 1
}
}
热门推荐
“食色性也”的来历 食色性也是谁提出的?
高血压早发现早治疗,远离6大高危并发症,每一个都可能致命
幼师专业主要学什么?2025年高考生必看的职业指南
如何查询已购房产是否已备案?
春天小孩吃什么长高增强抵抗力
冬季,肌营养不良患者多吃养脾胃食物 坚持冬天 脾胃强了 阳气足了,虚寒少了
股票涨停的判断依据有哪些?如何根据涨停情况制定投资策略?
专有建筑面积是指什么?
各岗位如何加强协作能力
筋膜炎的症状及治疗
筋膜炎是指什么病
预付款保函金额是怎样规定的
黄芪-红花如何神奇逆转脑缺血/再灌注损伤:空间代谢组学的惊人发现!
lols6劫到底厉害不厉害?(分析劫在S6中的表现及优缺点)
日本最宜居的城市有哪些?
国产蓝莓“上位” 味美价廉惹人爱
播种绿色希望,共筑美好未来
轻松摆脱尬聊的AI表情包攻略
高考日语时间规划指南:高效备考策略与注意事项
光纤通信中的调制技术:长距离传输的关键
广东情侣下班后的二人晚餐,成本18块,拒绝外卖,好好吃饭
愿你是那朵铿锵玫瑰 ——女性成长专题
手冰凉是什么原因怎么办
别墅出租指南:从市场调研到税务合规的全方位攻略
苯磺酸氨氯地平片与苯磺酸左氨氯地平片哪个好
土耳其特色美食:必尝的19道土耳其料理
系统设计中跨时区问题解决方案
上市公司股东合规减持指南——外资大股东协议转让篇(上)
这七家图卢兹餐厅向法国美食致敬
看电影正中间位置最好?也许你选错了……