当前位置: 首页 > news >正文

网站备案流程实名认证哪个平台做网站好

网站备案流程实名认证,哪个平台做网站好,静态双语企业网站后台源码,做网站的地方LeetCode 热题 100 | 543. 二叉树的直径 大家好,今天我们来解决一道经典的二叉树问题——二叉树的直径。这道题在 LeetCode 上被标记为简单难度,要求计算给定二叉树的直径。 问题描述 给你一棵二叉树的根节点,返回该树的直径。二叉树的直径…

LeetCode 热题 100 | 543. 二叉树的直径

大家好,今天我们来解决一道经典的二叉树问题——二叉树的直径。这道题在 LeetCode 上被标记为简单难度,要求计算给定二叉树的直径。


问题描述

给你一棵二叉树的根节点,返回该树的直径。二叉树的直径是指树中任意两个节点之间最长路径的长度。这条路径可能经过也可能不经过根节点。

示例 1:

输入:root = [1,2,3,4,5]
输出:3
解释:3,取路径 [4,2,1,3] 或 [5,2,1,3] 的长度。

示例 2:

输入:root = [1,2]
输出:1

提示:

  • 树中节点数目在范围 [1, 10^4]
  • -100 <= Node.val <= 100

解题思路

核心思想
  1. 递归法

    • 使用递归法计算每个节点的左子树和右子树的最大深度。
    • 对于每个节点,计算其左子树深度和右子树深度之和,作为该节点的直径。
    • 更新全局最大直径。
  2. 辅助函数

    • 定义一个辅助函数 maxDepth,用于计算以某个节点为根的子树的最大深度。

Python代码实现

class Solution:def diameterOfBinaryTree(self, root: TreeNode) -> int:self.max_diameter = 0def maxDepth(node: TreeNode) -> int:if not node:return 0left_depth = maxDepth(node.left)right_depth = maxDepth(node.right)# 更新全局最大直径self.max_diameter = max(self.max_diameter, left_depth + right_depth)return max(left_depth, right_depth) + 1maxDepth(root)return self.max_diameter

代码解析

  1. 初始化

    • 定义一个全局变量 self.max_diameter,用于存储全局最大直径。
  2. 递归函数

    • 定义一个辅助函数 maxDepth,用于计算以某个节点为根的子树的最大深度。
    • 如果节点为空,返回 0。
    • 递归计算左子树和右子树的最大深度。
    • 更新全局最大直径为左子树深度和右子树深度之和。
    • 返回当前节点的最大深度。
  3. 主函数

    • 调用 maxDepth 函数,从根节点开始计算最大深度。
    • 返回全局最大直径。

复杂度分析

  • 时间复杂度:O(n),其中 n 是树中节点的数量。每个节点被访问一次。
  • 空间复杂度:O(h),其中 h 是树的高度。递归调用栈的深度最多为树的高度。

示例运行

示例 1
输入:root = [1,2,3,4,5]
输出:3
解释:3,取路径 [4,2,1,3] 或 [5,2,1,3] 的长度。
示例 2
输入:root = [1,2]
输出:1

总结

通过递归法,我们可以高效地计算二叉树的直径。递归函数 maxDepth 用于计算每个节点的左子树和右子树的最大深度,并更新全局最大直径。希望这篇题解对大家有所帮助,如果有任何问题,欢迎在评论区留言讨论!

关注我,获取更多算法题解和编程技巧!

http://www.dtcms.com/a/499593.html

相关文章:

  • 最版网站建设案例中国建设银行开户行查询
  • 衡水网站制作多少钱世界著名产品设计作品
  • 我们如何更好地相处和协作?
  • Vlanif的作用
  • 62.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--新增功能--自训练ML模型
  • 北京住房城乡建设网站秦皇岛手机网站制作公司
  • 【SpringBoot从初学者到专家的成长18】SpringBoot中的数据持久化:JPA与Hibernate的结合
  • Ubuntu服务器已下载Nginx安装包的安装指南
  • 高可用Prometheus问题集锦
  • wap建站模板物流网站怎么开
  • 【Leetcode hot 100】763.划分字母区间
  • Agent向量存储中的记忆衰退与记忆过载解决方案
  • php网站跟随导航扁平化配色方案网站
  • 降噪算法的效果分析
  • FreeSWITCH RTP 自动调整花费时间太久
  • 怎么在一个网站做编辑一流的镇江网站优化
  • 常用电子元器件学习总结
  • TCP/IP协议相关知识点
  • 网站点播视频如何做帮助做APP的网站公司
  • 直圆锥(Right Circular Cone)
  • vue适合做门户网站吗企业官网下载
  • 熬夜肌救星:EGT+AKG+SOD科学修护
  • 上海住房城乡建设网站成都创软科技的口碑
  • 建设银行网站建设情况网络维护公司需要什么资质
  • 解决stm32cubeide工程复制后更改路径导致无法识别问题
  • GitHub 热榜项目 - 日榜(2025-10-18)
  • 【问题】Mac 的 Finder 中没有桌面选项如何处理?(访达 -> 设置 -> 边栏 -> 勾选桌面)
  • string类介绍
  • 深度学习物理神经网络(PINN)!
  • 青岛做公司网站的公司ppt模板下载简约