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

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节点吗!
在这里插入图片描述

http://www.lryc.cn/news/2394043.html

相关文章:

  • 行为型:解释器模式
  • 逻辑回归详解:从原理到实践
  • FastAPI集成APsecheduler的BackgroundScheduler+mongodb(精简)
  • 本地部署FreeGPT+内网穿透公网远程访问,搞定ChatGPT外网访问难题
  • linux 1.0.3
  • 基于RK3588的智慧农场系统开发|RS485总线|华为云IOT|node-red|MQTT
  • 解锁程序人生学习成长密码,从目标设定开始
  • 简单cnn
  • C#集合循环删除某些行
  • 相机定屏问题分析四:【cameraserver 最大request buffer超标】后置视频模式预览定屏闪退至桌面
  • 【Linux 学习计划】-- 进程地址空间
  • 告别重复 - Ansible 配置管理入门与核心价值
  • 3D Gaussian splatting 04: 代码阅读-提取相机位姿和稀疏点云
  • CTFHub-RCE 命令注入-过滤空格
  • 卫生间改造翻新怎么选产品?我在瑞尔特找到了解决方案
  • C++ list数据删除、list数据访问、list反转链表、list数据排序
  • Express教程【002】:Express监听GET和POST请求
  • mysql安装教程--笔记
  • C++ 观察者模式:设计与实现详解
  • 【PostgreSQL 03】PostGIS空间数据深度实战:从地图服务到智慧城市
  • HIT-csapp大作业:程序人生-HELLO‘s P2P
  • 深入探讨redis:主从复制
  • 帕金森常见情况解读
  • 清华大学发Nature!光学工程+神经网络创新结合
  • 【android bluetooth 案例分析 04】【Carplay 详解 3】【Carplay 连接之车机主动连手机】
  • C++学习-入门到精通【11】输入/输出流的深入剖析
  • NW969NW978美光闪存颗粒NW980NW984
  • 使用 ssld 提取CMS 签名并重签名
  • 前端基础之《Vue(17)—路由集成》
  • 大厂前端研发岗位PWA面试题及解析