代码随想录 Day13 二叉树 LeetCode T104 二叉树的最大深度 T111 二叉树的最小深度 T222完全二叉树的节点个数

news2025/1/13 8:46:25

以下题解的更详细思路来自于:代码随想录 (programmercarl.com)

前言

二叉树的高度与深度

这里先补充一下二叉树深度和高度的概念

高度:二叉树中任意一个节点到叶子结点的距离

深度:二叉树中任意一个节点到根节点的距离

下面给出一个图便于理解

获取高度与深度的遍历方式

高度:后序遍历

深度:前序遍历

那么为什么是这两种方式呢?

高度:(从下往上计数)后序遍历可以获取左右子树的高度最后返回给父节点

深度:(从上往下计数)往下遍历一个我们就加1,也符合求深度的过程,前序遍历刚好可以满足需求

 LeetCode T104 二叉树的最大深度

题目链接:104. 二叉树的最大深度 - 力扣(LeetCode)

题目思路:

首先我要说的是,这道题虽然是求最大深度,但是前序遍历和后序遍历都可以解决问题,这里我们选择使用后序遍历解决问题,有人会问,刚刚不是说前序遍历更好解决深度问题吗,为什么使用后序遍历呢?这是因为最大深度就是二叉树的根节点的高度, 这里我们将最大深度转化为了根节点 的高度来求解,我们仍然采用递归去求解,分三步.

1.确定返回值和参数类型

int getHeight(TreeNode node)

2.确定递归结束条件

if(node == null)
    {
        return 0;
    }

3.确定单层递归的代码

        int leftHeight = getHeight(node.left);
        int rightHeight = getHeight(node.right);
        int height = leftHeight>rightHeight?leftHeight+1:rightHeight+1;
        return height;

题目代码:


class Solution {
    public int maxDepth(TreeNode root) {
        return getHeight(root);

    }
    public int getHeight(TreeNode node)
    {
        if(node == null)
        {
            return 0;
        }
        int leftHeight = getHeight(node.left);
        int rightHeight = getHeight(node.right);
        int height = leftHeight>rightHeight?leftHeight+1:rightHeight+1;
        return height;
    }
}

LeetCode T111 二叉树的最小深度

题目链接:111. 二叉树的最小深度 - 力扣(LeetCode)

题目思路:

这题我们也能延续上题的思想,不过需要做特殊的处理,我们这里同样使用后序遍历来解决问题,但是要注意不是在上题的基础上把最大值改成最小值即可,因为这里我们是从叶子节点到根节点的距离,这里假设我们左子树为空,用上题的求最大深度的思路解决问题就会发现不成立,如果依据上题的思路这里的最小深度就为1,而实际上这题的最小深度是3,这里我们开始递归三部曲

1.确定参数和返回值

 public int getHeight(TreeNode node)

2.确定递归结束条件

if(node == null)
    {
        return 0;
    }

3.确定单层递归逻辑

        int rightHeight = getHeight(node.right);
        int leftHeight = getHeight(node.left);
        if(node.left == null && node.right != null)
        {
            return rightHeight+1;
        }
        if(node.left != null && node.right == null)
        {
            return leftHeight+1;
        }
        return leftHeight>rightHeight?rightHeight+1:leftHeight+1;

这里我们要考虑某个子树为空而另一个子树不为空的情况,我们去返回不为空的子树+1

题目代码:

class Solution {
    public int minDepth(TreeNode root) {
        return getHeight(root);

    }
    public int getHeight(TreeNode node)
    {
        if(node == null)
        {
            return 0;
        }
        int rightHeight = getHeight(node.right);
        int leftHeight = getHeight(node.left);
        if(node.left == null && node.right != null)
        {
            return rightHeight+1;
        }
        if(node.left != null && node.right == null)
        {
            return leftHeight+1;
        }
        return leftHeight>rightHeight?rightHeight+1:leftHeight+1;
    }
}

LeetCode T222 完全二叉树的节点个数

题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目思路:

这里我们知道对于满二叉树,我们的节点数是2^(深度-1)次方,由此我们可以判断如果左边递归到底的深度等于右边递归到底的深度,那么就可以使用这个公式计算,这样也减少了对中间节点的遍历.我们继续进行递归三部曲(后序遍历)

1.返回值和形参列表

public int getNum(TreeNode node)

2.终止条件

        if(node == null)
        {
            return 0;
        }
        int leftDepth=0,rightDepth = 0;
        TreeNode left = node.left;
        TreeNode right = node.right;
        while(right != null)
        {
            right = right.right;
            leftDepth++;
        }
        while(left != null)
        {
            left = left.left;
            leftDepth++;
        }
        if(leftDepth == rightDepth)
        {
            return (2>>leftDepth)-1;
        }

3.一层递归逻辑

        int leftnum= getNum(node.left);
        int rightnum = getNum(node.right);
        int result = leftnum + rightnum+1;
        return result;

题目代码:

class Solution {
    public int countNodes(TreeNode root) {
        return getNum(root);

    }
    public int getNum(TreeNode node)
    {
        //终止条件
        if(node == null)
        {
            return 0;
        }
        int leftDepth=0,rightDepth = 0;
        TreeNode left = node.left;
        TreeNode right = node.right;
        while(right != null)
        {
            right = right.right;
            leftDepth++;
        }
        while(left != null)
        {
            left = left.left;
            leftDepth++;
        }
        if(leftDepth == rightDepth)
        {
            return (2>>leftDepth)-1;
        }
        int leftnum= getNum(node.left);
        int rightnum = getNum(node.right);
        int result = leftnum + rightnum+1;
        return result;

    }
}

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

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

相关文章

python scanpy spatial空转全流程

Spatial mapping of cell types across the mouse brain (1/3) - estimating reference expression signatures of cell types — cell2location documentation Spatial mapping of cell types across the mouse brain (2/3) - cell2location — cell2location documentation #…

文件扫描模块

文章目录 前言文件扫描模块设计初级扫描方案一实现单线程扫描整合扫描步骤 设计初级扫描方案二周期性扫描 总结 前言 我们这个模块考虑的是数据库里面的内容从哪里获取。 获取完成后,这时候,我们就需要把目录里面文件/子文件都获取出来,并存入数据库。 文件扫描模…

Flask-[项目]-搭建短网址系统:flask实现短网址系统,短网址系统,构建短网址系统

一、项目下载地址 https://gitee.com/liuhaizhang/short-url-systemhttps://gitee.com/liuhaizhang/short-url-system 二、项目搭建 2.1、基本环境安装 1、安装好mysql数据库 2、安装好redis数据 3、安装好python解释器 2.2、项目依赖安装 1、切换到python解释器环境中 …

MES管理系统在制造业中的应用及其核心构成

在制造业的信息化进程中,车间级的信息化一直是其薄弱环节。为了提升车间的自动化水平,发展MES数字化技术成为了有效的途径。MES管理系统强调车间级的过程集成、控制和监控,合理地配置和组织所有资源,以满足车间的信息化需求。它提…

5G商企专网,助力打造城市生命线“安徽样板”

为扎实抓好重点领域安全监管,防范各类生产突发事故发生,近年来,安徽芜湖启动了城市生命线工程项目,致力于打造城市生命线“安徽样板”。 项目建设如火如荼,一些难题也不断涌现。比如,为提升城市安全保障能…

浅谈电动汽车智能充电桩及运营管理云解决方案

贾丽丽 安科瑞电气股份有限公司 上海嘉定 201801 摘要:电动汽车采用了电力作为发动能源,但是同样存在很大缺陷,即续航能力方面存在较大不足。因此如何利用现代技术进行电动汽车的智 能充电便十分重要。在电动汽车智能充 电的研究过程中需要用到的技术有…

Kubernetes概述架构与工作流程简述

文章目录 Kubernetes概述Kubernetes优势Kubernetes 集群组件控制平面组件Node 组件 Kubernetes工作流程下期预告 Kubernetes概述 Kubernetes 是一个可移植、可扩展的开源平台,用于管理容器化的工作负载和服务,可促进声明式配置和自动化。 Kubernetes 拥…

pyppeteer 基本用法和案例

特点 自带chromium 不用自己下载也可以下载,比较省事.比selenium好用 可异步调用 简介 一. pyppeteer介绍 Puppeteer是谷歌出品的一款基于Node.js开发的一款工具,主要是用来操纵Chrome浏览器的 API,通过Javascript代码来操纵Chrome浏览器&am…

Columbus:一个基于API实现的子域名发现服务工具

关于Columbus【点击领取安装包】 Columbus是一款功能强大的子域名发现与枚举工具,该工具基于API实现其功能,并且还提供了很多其他的高级功能。在该工具的帮助下,广大研究人员可以快速且高效地实现子域名枚举任务。 【点击领取安装包】 前端…

接口测试复习Requests PyMysql Dubbo

一。基本概念 接口概念:系统与系统之间 数据交互的通道。 接⼝测试概念:校验 预期结果 与 实际结果 是否⼀致。 特征: 测试⻚⾯测试发现不了的问题。(因为:接⼝测试 绕过前端界⾯。 ) 符合质量控制前移理…

【开发篇】十八、SpringBoot整合ActiveMQ

文章目录 1、安装ActiveMQ2、整合3、发送消息到队列4、使用消息监听器对消息队列监听5、流程性业务消息消费完转入下一个消息队列6、发布订阅模型 1、安装ActiveMQ docker安装 docker pull webcenter/activemqdocker run -d --name activemq -p 61616:61616 -p 8161:8161 webce…

Pikachu靶场——跨站请求伪造(CSRF)

文章目录 1. 跨站请求伪造(CSRF)1.1 CSRF(get)1.2 CSRF(post)1.3 CSRF Token1.4 CSRF漏洞防御 1. 跨站请求伪造(CSRF) 还可以参考我的另一篇文章:跨站请求伪造(CSRF) 全称Cross-site request forgery,翻译…

DRM全解析 —— plane详解(1)

本文参考以下博文: Linux内核4.14版本——drm框架分析(5)——plane分析 特此致谢! 1. 简介 一个plane代表一个image layer(硬件图层),最终的image由一个或者多个plane(s)组成。plane和 Framebuffer 一样是内存地址。…

软信天成:医药企业数据整合难、共享难?这套企业级数据治理体系是关键

在数字化时代,数据已成为企业发展的核心资产。然而,对于拥有十余个业务系统的某大型国有医药企业(下文简称案例企业)来说,数据整合难、共享难等问题却一直存在。面对庞杂的数据来源和多样化的数据格式,传统…

Datawhale团队第十期录取名单!

Datawhale团队 公示:Datawhale团队成员 Datawhale成立四年了,从一开始的12个人,学习互助,到提议成立开源组织,做更多开源的事情,帮助更多学习者,也促使我们更好地成长。于是有了我们的使命&…

OpenAI重大更新!为ChatGPT推出语音和图像交互功能

原创 | 文 BFT机器人 OpenAI旗下的ChatGPT正在迎来一次重大更新,这个聊天机器人现在能够与用户进行语音对话,并且可以通过图像进行交互,将其功能推向与苹果的Siri等受欢迎的人工智能助手更接近的水平。这标志着生成式人工智能运动的一个显著…

Embedding技术与应用 (2) :神经网络的发展及现代Embedding方法简介

编者按:IDP开启Embedding系列专栏,详细介绍Embedding的发展史、主要技术和应用。 本文是《Embedding技术与应用系列》的第二篇,重点介绍 神经网络的发展历程及其技术架构,剖析了嵌入技术与这些神经网络(Transformer、B…

通讯网关软件017——利用CommGate X2Modbus实现Modbus RTU访问MSSQL服务器

本文介绍利用CommGate X2Modbus实现Modbus RTU访问MS SQL数据库。CommGate X2MODBUS是宁波科安网信开发的网关软件,软件可以登录到网信智汇(http://wangxinzhihui.com)下载。 【案例】如下图所示,实现上位机通过Modbus RTU来获取MS SQL数据库的数据。 【…

解密人工智能:决策树 | 随机森林 | 朴素贝叶斯

文章目录 一、机器学习算法简介1.1 机器学习算法包含的两个步骤1.2 机器学习算法的分类 二、决策树2.1 优点2.2 缺点 三、随机森林四、Naive Bayes(朴素贝叶斯)五、结语 一、机器学习算法简介 机器学习算法是一种基于数据和经验的算法,通过对…

0基础学习VR全景平台篇 第104篇:720全景后期软件安装

上课!全体起立~ 大家好,欢迎观看蛙色官方系列全景摄影课程! 摄影进入数码时代,后期软件继承“暗房工艺”,成为摄影师表达内在情感的必备工具。 首先说明,全景摄影与平面摄影的一个显著的区别是全景图片需…