高频编程考题:二叉树的直径(简单)
创作时间:
作者:
@小白创作中心
高频编程考题:二叉树的直径(简单)
引用
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
}
}
热门推荐
新型装甲材料将重塑未来坦克战场
GL-6主动防护系统:坦克生存率大揭秘!
中国GL6坦克防护系统:空中威胁终结者?
景嘉微发布新型坦克防护系统:360°全方位防护,民营科技助力国防创新
在北京选择合适的驾校?这些关键因素帮你做出明智选择
聆听古祠的岁月回响
交通运输部:已建设充电设施的高速公路服务区占比提升到97%
“荔泮芳华”:走进陈家祠,聆听百年古祠历史故事
减脂期间一日三餐怎么吃?这份饮食指南请收好
练习口才的基本方法,每天朗读文章能让口齿更加清晰伶俐
春秋五霸的说法有很多,为何只有齐桓公、晋文公和楚庄王被公认
双十一后,用云学堂提升企业防骗能力
揭秘抖音刷单诈骗:从红包诱惑到技术陷阱
揭秘刷单诈骗:沉没成本效应如何让你一步步陷入陷阱?
刷单被骗后如何追回资金?立即报警!
用情绪管理改善亲子关系:从觉察到行动
提升职场竞争力,你的情绪价值够高吗?
《花儿与少年》:一场关于情绪价值的心灵之旅
捕捉最美瞬间:219国道西藏段+珠峰摄影攻略
G219国道西藏段自驾游攻略:如何应对高反?
自动挡上陡坡,这些技巧你必须知道!
冬季越野车最大爬坡角度测试:实验室模拟与实地验证
大货车爬坡没劲?这些技巧帮你搞定!
警惕!新型诈骗盯上未成年人,这些套路要当心
北京互联网法院:孩子遭骗后的法律保护
家长必看!如何预防孩子遭遇电信诈骗?
政策引领创新驱动:中国电动车产业的绿色崛起
布尔津风味烤鲈鱼,在家也能做!
卡维地洛:心血管疾病治疗的新选择
降压药新突破:卡维地洛或可治疗癫痫