Leetcode Hot 100 | 543.二叉树的直径 | 递归+优化

news2024/12/23 4:19:19

写法一

自己一开始直接写的,没考虑时间复杂度…

class Solution {
    /*
        递归思路:不准进递归(除非之后用简单例子验证一下)
            将方法按照自己想要返回的值来补充其他的代码细节;
            用最值来模拟返回结果+补充代码细节(最高和最低);
            再用简单例子走一遍全过程修改代码
    */

    //计算对当前结点来说的最大直径 【递归调用】
    public int diameterOfBinaryTree(TreeNode root) {
        //【边界用最低来模拟】
        if(root == null)
            return 0;

        //【用最高来模拟】
        //算当前结点的最大直径
        int res1 = maxHeight(root.left)+maxHeight(root.right);
        //算当前结点的左子结点的最大直径
        int res2 = diameterOfBinaryTree(root.left);
        //算当前结点的右子结点的最大直径
        int res3 = diameterOfBinaryTree(root.right);

        //三个值里面取最大值
        int res4 = Math.max(res1,res2);
        int res = Math.max(res3,res4);
        
        //返回直径最大值
        return res;
    }

    // 计算当前结点到其左结点(或右结点)最底端的最长高度 (经过的枝) 【递归调用】
    // 【其实准确计算的是当前结点到其左结点(或右结点)最底端经过的最多的结点 【只不过结点比树枝少1 (2结点=1树枝) ;(刚好在调用处就不用再+1了(即不用算连接根的那个枝了))】】
    public int maxHeight(TreeNode node){
        //【边界用最低来模拟】
        if(node == null)
            return 0;
        
        //【用最高来模拟】
        int res1 = maxHeight(node.left);
        int res2 = maxHeight(node.right);
        return Math.max(res1,res2)+1;
    }
}

时间和内存:
在这里插入图片描述

写法二:优化了下

class Solution {

    public int res = 0;

    public int diameterOfBinaryTree(TreeNode root) {
        /**
         * 和法一写的区别:
         *  1.该函数只负责调用不负责返回值;方法一函数负责返回值,在调用处才计算 【能在函数内实现就在函数内实现,简单高效快捷美观】
         *  2.该函数传入的是root,直接内部递归计算左右结点了(不用返回root值,最多就返回到root的左右子结点,刚好能计算以root为根的直径);方法一传入的是左右结点,而且还递归传入...【这个方法的优化高效省内存节省时间】
         *  3.该方法的res是全局变量,递归一次就能计算好(边递归边计算的);方法一的res是全部递归之后才算的,每次都递归root和左右根的计算...【太耗了,这个的一次递归计算更方便!】
         */

        //传root进去,只是递归计算其所有左结点(右结点)数量【即以root为根的树杈】
        culculateDiameter(root);
        return res;
    }

    /*(假设左边有三道左结点)当前结点返回给上一层结点包括当前结点在内的所有子结点的个数 = 当前的层数 = 对上一层结点来说接收的就是以上一层结点为根的所有树杈数量
        即:结点数 = 层数 = 杈数+1 ; 深度 = 层数 , 长度 = 杈数
     */
    //这里最多用到root的左右子结点的返回值返回完就结束了,最后一次返回值给调用处的root没用,所以虽然计算的是结点数,但用到的还是结点数-1=树杈数
    public int culculateDiameter(TreeNode node){
        if(node == null) return 0;

        int l = culculateDiameter(node.left);
        int r = culculateDiameter(node.right);
        res = Math.max(res,l+r);

        return Math.max(l,r)+1;
    }

}

浅优化了一点耗时
在这里插入图片描述

后续有别的方法或优化写法再补充

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Win10鼠标总是频繁自动失去焦点-非常有效-重启之后立竿见影

针对Win10鼠标频繁自动失去焦点的问题,可以尝试以下解决方案: 一、修改注册表(最有效的方法-重启之后立竿见影) 打开注册表编辑器: 按下WindowsR组合键,打开运行窗口。在运行窗口中输入“regedit”&#x…

什么是reactor以及其三种版本

写在前面 本文来看下什么是reactor以及其三种版本。 1:什么是reactor以及其三种版本 为了更好的理解什么是reactor,我们结合现实生活中的例子来看下。 翠花是个貌美如花的姑娘,人称赛东施,她的梦想是嫁给王子,可是天…

【机器学习-无监督学习】降维与主成分分析

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈Python机器学习 ⌋ ⌋ ⌋ 机器学习是一门人工智能的分支学科,通过算法和模型让计算机从数据中学习,进行模型训练和优化,做出预测、分类和决策支持。Python成为机器学习的首选语言,…

揭秘帕金森病:多因素交织下的“沉默杀手”

在老年人群中,帕金森病如同一位“沉默的杀手”,悄然侵袭着无数人的生活。它以其独特的静止性震颤、运动迟缓、肌强直和姿势平衡障碍等症状,让患者的生活质量大打折扣。那么,帕金森病究竟是如何得的呢?本文将带您深入探…

基于Springboot+Vue的基于协同过滤算法的个性化音乐推荐系统 (含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统中…

Android 13.0 系统wifi列表显示已连接但无法访问网络问题解决

1.前言 在13.0的系统rom产品定制化开发中,在wifi模块也很重要,但是在某些情况下对于一些wifi连接成功后,确显示已连接成功,但是无法访问互联网 的情况,所以实际上这时可以正常上网的,就是显示的不正常,所以就需要分析连接流程然后解决问题 如图所示: 2.系统wifi列表显示…

【Spring Boot 入门三】Spring Boot与数据库集成 - 构建数据驱动的应用

一、引言 在之前的文章中,我们已经对Spring Boot有了初步的认识,了解了如何构建第一个Spring Boot应用,以及如何通过配置文件来掌控应用的设置。这些知识为我们进一步探索Spring Boot与数据库的集成奠定了坚实的基础。 数据库是现代应用的核…

QSqlDatabase在多线程中的使用

Qt中多线程使用数据库_qt数据库管理类支持多数据库,多线程-CSDN博客 1. 代码&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPushButton> #include <QSqlDatabase> #include <QSqlQuery> #include <QSqlError>…

【原创】基于websocket的实时文本转语音功能

功能实现&#xff0c;将长文本分段实时转成音频流&#xff0c;达到边转换边播放的效果&#xff0c;减少等待效果&#xff0c;像豆包通义千问chatgpt差不多也是这样实现的&#xff0c; 下面的效果展示 20240930_084035_哔哩哔哩_bilibili【原创】基于websocket的实时文本转语音…

Java 每日一刊(第18期):集合

文章目录 前言1. Java 集合框架概述1.1 Java 集合框架的定义和意义1.2 Java 集合框架的历史演进1.3 集合框架的基本组成部分1.4 Java 集合的优势1.5 Java 集合与数组的区别与关系 2. Java 集合框架的核心接口2.1 Collection 接口2.2 List 接口2.3 Set 接口2.4 Queue 接口2.5 Ma…

无人机在科研与教育领域的应用!

一、无人机在科研领域的应用 地理测绘与遥感&#xff1a; 无人机可以搭载相机或激光雷达等传感器&#xff0c;进行高分辨率的航拍&#xff0c;用于制作数字地形模型、生态环境监测、土地利用规划等。 在地理信息获取、地质勘察等领域&#xff0c;无人机能够高效地完成测量任…

Java中正则表达式(完整详解,附有案例+代码)

文章目录 三十三.正则表达式33.1 概述33.2 Test 三十三.正则表达式 33.1 概述 字符类 [abc]a、b 或 c&#xff08;简单类&#xff09;[^abc]任何字符&#xff0c;除了 a、b 或 c&#xff08;否定&#xff09;[a-zA-Z]a 到 z 或 A 到 Z&#xff0c;两头的字母包括在内&#x…

MQTT--EMQX入门+MQTTX使用

目录 1、什么是EMQX&#xff1f;1.1 EMQX介绍1.2 EMQX特点1.3 与物联网之间的关系以及主要的产品主要的产品 2、安装启动2.1 基本命令2.2 目录结构 3、MQTTX客户端3.1 连接配置 总结PS: 1、什么是EMQX&#xff1f; 首先你得有MQTT的知识&#xff0c;不认识MQTT的小伙伴可以先看…

JMeter对jdbc request以及foreach和loop controller的使用

Jmeter中jdbc request和foreach控制器 1. 使用variable name实现对数据库查询结果的遍历 在foreach controller中&#xff0c;注意要做variable name的关联(correlation), 否则没法取回这里的jdbc request返回的结果。这里的input variable prefix一定要和jdbc request中的var…

十七、触发器

文章目录 0. 引入1. 触发器概述2. 触发器的创建2.1 触发器的创建2.2 代码举例 3. 查看、删除触发器3.1 查看触发器3.2 删除触发器 4. 触发器的优缺点4.1 优点4.2 缺点4.3 注意点 0. 引入 在实际开发中&#xff0c;我们经常会遇到这样的情况&#xff1a;有 2 个或者多个相互关联…

《蓝桥杯算法入门》(C/C++、Java、Python三个版本)24年10月出版

推荐&#xff1a;《算法竞赛》&#xff0c;算法竞赛大全书&#xff0c;网购&#xff1a;京东 天猫  当当 文章目录 《蓝桥杯算法入门》内容简介本书读者对象作者简介联系与交流《蓝桥杯算法入门 C/C》版目录 《蓝桥杯算法入门 Java》版目录 《蓝桥杯算法入门 Python》版目录 …

vscode 连接服务器 不用输密码 免密登录

vscode 免密登录服务器 1. 本地端1&#xff09;生成密钥2&#xff09;vscode的config文件中添加id_rsa文件路径 2. 服务器端1&#xff09;在 authorized_keys 文件中加入密钥&#xff1a;2&#xff09;修改authorized_keys文件权限 1. 本地端 1&#xff09;生成密钥 在命令行…

【hot100-java】【二叉树的层序遍历】

二叉树 BFS 队列实现 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right)…

力扣(leetcode)每日一题 1845 座位预约管理系统| treeSet和priority Queue的区别|线段树

之前发过一篇&#xff0c;感觉还有深挖的地方&#xff0c;于是又补充一些信息 这题目虽然是middle难度题目&#xff0c;要解答出来是只要easy的时间&#xff0c;但是深挖可以有hard的难度 题解1 可以帮助复习线段树的使用&#xff0c;题解2 可以复习一下java基础知识 题解1 线…

免费送源码:Java+ssm+MySQL springboot健康医疗系统 计算机毕业设计原创定制

摘 要 随着我国经济迅速发展&#xff0c;人们对医疗管理的需求越来越大&#xff0c;各种健康医疗系统也都在被广泛应用&#xff0c;对于医疗管理的各种软件也是备受用户的喜爱&#xff0c;健康医疗系统被用户普遍使用&#xff0c;为方便用户能够可以随时进行健康医疗系统的数据…