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

leetcode hot100刷题日记——31.二叉树的直径

二叉树直径详解

    • 题目描述
    • 对直径的理解
    • 解答:dfs
      • 小TIPS

题目描述

在这里插入图片描述
在这里插入图片描述

对直径的理解

在这里插入图片描述
实际上,二叉树的任意一条路径均可以被看作由某个节点为起点,从其左儿子和右儿子向下遍历的路径拼接得到。

那我们找二叉树的直径(最大路径),就是需要:以左儿子为根节点的二叉树的深度,以右儿子为根节点的二叉树的深度,所有左深度加右深度的和中的最大值就是直径

而我们在计算二叉树的深度的时候,可以利用要比较左右子树深度这一点来计算路径。

(有了左深度,有了右深度,一加起来不就是路径长度嘛!全部记录下来找最大值就是路径啦~
在题解中表现为每次都和当前最大值比较,更新最大值)

解答:dfs

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int max_depth;//记录直径int depth(TreeNode* cur){if(cur==nullptr){//如果当前节点是空,说明遍历到头了,返回0return 0;}        int depth_L=depth(cur->left);//当前节点左子树深度int depth_R=depth(cur->right);//当前节点右子树深度max_depth=max(depth_L+depth_R,max_depth);//计算经过当前节点的路径,更新直径潜在值return max(depth_L,depth_R)+1;//每次返回左右子树中的更深子树的深度+1,因为自己也算一层}int diameterOfBinaryTree(TreeNode* root) {depth(root);//depth函数计算以节点root为根的深度return max_depth;}
};

时间复杂度:O(N),N为二叉树节点数
空间复杂度:O(height),height为二叉树的高度

小TIPS

不要这样理解直径啊!这不是又走了一遍2节点吗!
在这里插入图片描述

相关文章:

  • [GHCTF 2025]SQL???
  • leetcode hot100刷题日记——32.杨辉三角
  • CppCon 2014 学习: The Implementation of Value Types
  • 深入理解 Java 中的 Unsafe 类:原理、应用与风险
  • Java并发编程实战 Day 1:Java并发编程基础与线程模型
  • [SLAM自救笔记0]:开端
  • 字符串索引、幻读的解决方法
  • 玩客云WS1608控制LED灯的颜色
  • RLHF奖励模型的训练
  • 【Qt】EventFilter,要增加事件拦截器才能拦截到事件
  • 数据库只更新特定字段的两种方式(先读后写 vs. 动态组织 SQL)-golang SQLx 实现代码(动态组织 SQL)
  • 【设计模式-4.6】行为型——状态模式
  • 电路学习(二)之电容
  • Win10 doccano pip安装笔记
  • 【深度学习】16. Deep Generative Models:生成对抗网络(GAN)
  • STM32CubeMX串口配置
  • LeetCode[257]二叉树的所有路径
  • 【图像处理入门】3. 几何变换基础:从平移旋转到插值魔法
  • 基于开源AI大模型AI智能名片S2B2C商城小程序源码的销售环节数字化实现路径研究
  • 接口性能优化
  • flash网站建设方案/东莞seo外包公司哪家好
  • 电子商务网站建设的基本流程/b2b外贸平台
  • 天津网站app建设/互联网营销师是干什么的
  • 公司做网站开发流程/网络整合营销
  • 石龙网站建设/刷粉网站推广免费
  • 广州网站建设多少钱/seo搜索引擎优化技术