二叉树的直径,力扣

目录

题目地址:

题目:

我们直接看题解吧:

审题目+事例+提示:

解题方法:

难度分析:

解题方法分析:

解题分析:

补充说明:

代码优化:


题目地址:

543. 二叉树的直径 - 力扣(LeetCode)

难度:简单

今天刷二叉树的直径,大家有兴趣可以点上面链接,看看题目要求,试着做一下。

题目:

给你一棵二叉树的根节点,返回该树的 直径 。

二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。

两节点之间路径的 长度 由它们之间边数表示。

我们直接看题解吧:

审题目+事例+提示:

二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。

两节点之间路径的 长度 由它们之间边数表示。

解题方法:

方法为  深度搜索(DFS)

难度分析:

主要难在边与节点的关系,求直径即求路径长度,关键在求边

解题方法分析:

树的遍历方式总体分为两类:深度优先搜索(DFS)、广度优先搜索(BFS)。

常见 DFS : 先序遍历、中序遍历、后序遍历。

相关解题文章链接:

二叉树的前序遍历,力扣-CSDN博客

二叉树的中序遍历,力扣-CSDN博客

二叉树的中序遍历,力扣-CSDN博客

常见 BFS : 层序遍历(即按层遍历)。

相关解题文章链接:

二叉树的层序遍历,力扣-CSDN博客

求二叉树的最大深度

二叉树的最大深度,力扣-CSDN博客

解题分析:

首先我们知道

一条路径的长度为该路径经过的节点数-1即边数,

所以求直径(即求路径长度的最大值)等效于

求路径经过节点数的最大值-1。

而任意一条路径均可以被看作由某个节点为起点,从其左儿子和右儿子向下遍历的路径拼接得到。

如图我们可以知道路径 [9, 4, 2, 5, 7, 8] 可以被看作以 2 为起点,从其左儿子向下遍历的路径 [2, 4, 9] 和从其右儿子向下遍历的路径 [2, 5, 7, 8] 拼接得到。

假设我们知道对于该节点的左儿子向下遍历经过最多的节点数 L(即以左儿子为根的子树的深度)和其右儿子向下遍历经过最多的节点数 R (即以右儿子为根的子树的深度),那么以该节点为起点的路径经过节点数的最大值即为 L+R+1(1即该节点) 。

我们记节点 node 为起点的路径经过节点数的最大值为dnode,

那么二叉树的直径就是所有节点dnode的最大值-1即边数。

解题思路:

1、设一个全局变量 ans 记录 dnoded的最大值

2、定义递归函depth(node) 计算 dnoded(函数返回该节点为根的子树的深度)

           ·设置终止递归,访问到空节点,即node=null,则返回0

           ·递归调用左右儿子分别求得它们为根的子树的深度 L 和 R,

           ·更新ans,即该节点的 dnoded值为L+R+1

           ·返回该节点为根的子树的深度即为max(L,R)+1

代码实现:

class Solution {
    int ans;    //设一个全局变量ans记录节点数的最大值
    public int diameterOfBinaryTree(TreeNode root) {
        ans = 1;
        depth(root);
        return ans - 1;  //节点数-1,即边数
    }
    public int depth(TreeNode node) {
        if (node == null) {
            return 0; // 访问到空节点了,返回0
        }
        int L = depth(node.left); // 左儿子为根的子树的深度
        int R = depth(node.right); // 右儿子为根的子树的深度
        ans = Math.max(ans, L+R+1); // 计算d_node即L+R+1 并更新ans
        return Math.max(L, R) + 1; // 返回该节点为根的子树的深度
    }
}

补充说明:

1、变量ans初始化为1,方便返回-1操作,当该树为空树时,边数为0

2、 在递归函数中,注意返回的是该节点为根的子树深度,而整棵数的直径为全局变量ans-1

3、可能有朋友已经发现代码里面的-1,+1操作有些脱裤子放屁之意,不过这样子其实有助于我们理解路径规律与解题思路

代码优化:

上面通过节点数让我们更好的理解路径的规律与求路径的思路方法,即通过点获取边 。

接下来,我们直接通过求边即可

class Solution {
    int maxd=0;//定义全局变量,初始化为0
    public int diameterOfBinaryTree(TreeNode root) {
        depth(root);
        return maxd;
    }
    public int depth(TreeNode node){
        if(node==null){
            return 0;
        }
        int Left = depth(node.left);
        int Right = depth(node.right);
        maxd=Math.max(Left+Right,maxd);//将每个节点最大直径(左子树深度+右子树深度)
                                           // 与当前最大值比较并取大者
        return Math.max(Left,Right)+1;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/302680.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

设计模式的艺术P1基础—2.2 类与类的UML图示

设计模式的艺术P1基础—2.2 类与类的UML图示 在UML 2.0的13种图形中,类图是使用频率最高的两种UML图之一(另一种是用于需求建模的用例图),它用于描述系统中所包含的类以及它们之间的相互关系,帮助人们简化对系统的理解…

指针传参误区

C语言中指针作为形参传递时,func(*a, *b) 这种形式的话,是无法通过简单的 ab来修改的,在函数体内a的地址确实被修改成b的地址了,但是当函数执行结束时,a的地址会重新回到原本的地址里面&#xf…

Mac安装upx及不同os计算md5值

Mac安装upx 最近需要将exe文件打包到pod内部,为了减少包占用磁盘空间,需要借用upx对windows exe文件进行压缩。 1 概念:压缩工具 UPX 全称是 “Ultimate Packer for eXecutables”,是一个免费、开源、编写、可扩展、高性能的可执行…

【C语言】编程世界的不朽基石与未来展望

C语言,一种经久不衰的高级编程语言,自1972年由Dennis Ritchie在AT&T贝尔实验室开发以来,已深深扎根于编程语言的发展历程中。它既是计算机科学史上的一个重要里程碑,也是现代软件开发的核心支柱。从操作系统到嵌入式系统的构建…

设计模式的艺术P1基础—第1章 概述

刘伟,2020 概述:4部分,26章。 P1:基础(1-2章) P2:创建型设计模式(创建艺术,3-8章) P3:结构型设计模式(组合艺术,9-15章) P4:行为型设计模式&…

基于Python的车牌识别系统实现

本文将以基于Python的车牌识别系统实现为方向,介绍车牌识别技术的基本原理、常用算法和方法,并详细讲解如何利用Python语言实现一个完整的车牌识别系统。 精彩专栏持续更新推荐订阅,收藏关注不迷路 微信小程序实战开发专栏 目录 引言车牌识别技术的应用场景Python在车牌识别…

从零学Java - String类

Java String类 文章目录 Java String类1 String1.1 常用两种创建方式1.2 比较两种创建方式1.3 字符串不可变性1.4 面试题 2 常用方法2.1 练习 3 可变字符串3.1 常用方法3.2 验证StringBuilder的高效性3.3 练习3.4 面试题: 4 正则表达式4.1 元字符4.2 其他字符4.2.1 预定义字符4…

MLP(多层感知机) 虚战1

使用Keras实现MLP 前两节地址: CSDNmatplotlib 虚战1-CSDN博客 (数据的获取在这有说明) 数据预处理 虚战1-CSDN博客CSDN 数据预处理的最后一步:将数据集分为 训练数据集、测试数据集和校验数据集。 训练数据集&#xff1a…

C++学习笔记——友元及重载运算符

目录 一、友元 1.1声明友元函数 1.2声明友元类 二、运算符重载 2.1重载加号运算符 2.2重载流插入运算符 三、一个简单的银行管理系统 四、 详细的介绍 一、友元 在 C 中,友元是一个函数或类,它可以访问另一个类的私有成员或保护成员。通常情况下…

RT-Thread 线程管理

线程管理 在日常生活中,我们要完成一个大任务,一般会将它分解成多个简单、容易解决的小问题,小问题逐个被解决,大问题也就随之解决了。 在多线程操作系统中,也同样需要开发人员把一个复杂的应用分解成多个小的、可调…

k8s--集群调度(kube-scheduler)

了解kube-scheduler 由之前博客可知kube-scheduler是k8s中master的核心组件之一 scheduler:负责调度资源。把pod调度到node节点。他有两种策略: 预算策略:人为部署,指定node节点去部署新建的pod 优先策略:通过算法选…

FineBI实战项目一(11):每日不同商品分类订单个数统计

1 明确数据分析目标 统计所有订单中的每种分类对应的商品的个数,构建词云图 2 创建用于保存数据分析结果的表 create table app_cat_cnt(id int primary key auto_increment,daystr varchar(20),catName varchar(100),cnt int ); 3 编写SQL语句进行数据分析 se…

亲测有效:腾讯云免费服务器30天申请流程

腾讯云免费服务器申请入口 https://curl.qcloud.com/FJhqoVDP 免费服务器可选轻量应用服务器和云服务器CVM,轻量配置可选2核2G3M、2核8G7M和4核8G12M,CVM云服务器可选2核2G3M和2核4G3M配置,腾讯云百科txybk.com分享2024年最新腾讯云免费服务器…

「MCU」SD NAND芯片之国产新选择优秀

文章目录 前言 传统SD卡和可贴片SD卡 传统SD卡 可贴片SD卡 实际使用 总结 前言 随着目前时代的快速发展,即使是使用MCU的项目上也经常有大数据存储的需求。可以看到经常有小伙伴这样提问: 大家好,请问有没有SD卡芯片,可以…

程序员必备的面试技巧

程序员必备的面试技巧 程序员必备的面试技巧,就像是编写一段完美的代码一样重要。在面试战场上,我们需要像忍者一样灵活,像侦探一样聪明,还要像无敌铁金刚一样坚定。只有掌握了这些技巧,我们才能在面试的舞台上闪耀光…

C# .Net学习笔记—— 异步和多线程(Task)

一、概念 Task是DotNet3.0之后所推出的一种新的使用多线程的方式,它是基于ThreadPool线程进行封装的。 二、使用多线程的时机 任务能够并发运行的时候,提升速度;优化体验 三、基本使用方法 private void button5_Click(object sender, Ev…

猫头虎分享已解决Bug || Go Error: cannot use str (type string) as type int in assignment

博主猫头虎的技术世界 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能! 专栏链接: 🔗 精选专栏: 《面试题大全》 — 面试准备的宝典!《IDEA开发秘籍》 — 提升你的IDEA技能!《100天精通Golang》…

以太网交换基础

0x00 前言 以为主要的作用的笔记的记忆,所以多为问答的形式进行记录。 什么是以太网? 以太网是一种局域网技术,用于链接终端,进行网络通信。 什么是冲突域? 冲突域是指连接在同一公共介质上的所有节点的集合。 就…

静态网页设计——多彩贵州(HTML+CSS+JavaScript)(dw、sublime Text、webstorm、HBuilder X)

前言 声明:该文章只是做技术分享,若侵权请联系我删除。!! 感谢大佬的视频:https://www.bilibili.com/video/BV1cK411v7R2/?vd_source5f425e0074a7f92921f53ab87712357b 源码:https://space.bilibili.com…

Spring——Spring的事务控制(2)升级篇

1.改造转账案例 1.1.applicationContext.xml <!--配置事物管理器--><bean class"org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name"dataSource" ref"dataSource"/></bean><!--配…