leetcode刷题-110 平衡二叉树的判断(递归实现)

题目描述

在这里插入图片描述

解题思路

首先解释一下,为什么会做到这个题目,因为博主在按顺序做题的过程中,碰到了一个不会做的题目(递归类型),就想着看看题解,发现了一个大佬的文章,就是专门讲的递归,里面包含了这个例子。就想着用python实现一下。进入正题。
首先,我们通常通过左右子树的高度差来判断该树是否是平衡二叉树,如果二叉树的高度差大于1,那么我们判断这个树不是平衡二叉树,反之,为平衡二叉树。知道这个思路那这个题目我们想象怎么用递归解决。
语言描述加上伪代码可能更容易表述。
1.首先空树是平衡二叉树,这个也是递归的终止条件。
我们可以这样写:

def isNB(root):
      if root==None:
         return ReturnNode(True,0)

2.接着是判断左右子树是否是平衡二叉树,代码又变成这样

def isNB(root):
      if root==None:
         return True
      left=isNB(root.left)
      right=isNB(root.right)

3.接下来,我们要考虑一个问题,对于当前子问题,只包含三个节点,根,左子树,右子树,我们根据其深度判断是否是平衡二叉树。原本的类中,只包含,左右子树,节点的值。不能满足我们的需要。此时我们需要重新定义一个结构体,此结构体,能够在递归的同时实现是否是平衡二叉树的判断,又能实现深度的计算。
定义新的类如下:

class ReturnNode:
    def __init__(self,isbalance=True,depth=0,):
        self.isbalance=isbalance
        self.depth=depth

那么之前写的代码就变成了这样

def isNB(root):
    if root==None:
        return ReturnNode(True,0)
    left=isNB(root.left)
    right=isNB(root.right)

接下来,我们需要考虑三个节点是否平衡,左右节点是否平衡,可以通过isbalance属性判断,当前节点的判断,需要凭借左右节点的深度值之差。代码如下。

def isNB(root):
    if root==None:
        return ReturnNode(True,0)
    left=isNB(root.left)
    right=isNB(root.right)
    if not right.isbalance:
        return ReturnNode(False,0)
    if not left.isbalance:
        return ReturnNode(False,0)
    if abs(left.depth-right.depth)<=1:
        return ReturnNode(True,max(left.depth,right.depth)+1)
    else:
        return ReturnNode(False,0)

大家可以看到在递归的同时,也实现了当前节点深度值的计算。

leetcode实现代码如下

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
#  
class ReturnNode:
    def __init__(self,isbalance=True,depth=0,):
        self.isbalance=isbalance
        self.depth=depth
class Solution:
    def isNB(root):
        if root==None:
            return ReturnNode(True,0)
        left=isNB(root.left)
        right=isNB(root.right)
        if not right.isbalance:
            return ReturnNode(False,0)
        if not left.isbalance:
            return ReturnNode(False,0)
        if abs(left.depth-right.depth)<=1:
            return ReturnNode(True,max(left.depth,right.depth)+1)
        else:
            return ReturnNode(False,0)


    def isBalanced(self, root: Optional[TreeNode]) -> bool:
        def isNB(root):
            if root==None:
                return ReturnNode(True,0)
            left=isNB(root.left)
            right=isNB(root.right)
            if not right.isbalance:
                return ReturnNode(False,0)
            if not left.isbalance:
                return ReturnNode(False,0)
            if abs(left.depth-right.depth)<=1:
                return ReturnNode(True,max(left.depth,right.depth)+1)
            else:
                return ReturnNode(False,0)
        return isNB(root).isbalance
 

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

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

相关文章

树及二叉树

文章目录 树定义相关概念树的表示 二叉树定义特殊的二叉树二叉树的性质 树 定义 树是一种非线性的数据结构&#xff0c;它由n个有限结点组成的有层次关系的集合。 如图所示&#xff0c;树的第一个结点是一个特殊的结点&#xff0c;它没有前驱结点&#xff0c;称为根结点。此外…

Linux系统部署Discuz论坛并发布至公网随时随地可远程访问

目录 ​编辑 前言 1.安装基础环境 2.一键部署Discuz 3.安装cpolar工具 4.配置域名访问Discuz 5.固定域名公网地址 6.配置Discuz论坛 结语 作者简介&#xff1a; 懒大王敲代码&#xff0c;计算机专业应届生 今天给大家聊聊Linux系统部署Discuz论坛并发布至公网随时随地…

06、MongoDB -- MongoDB 基本用法(删除文档、查询文档、查询运算符)

目录 MongoDB 基本用法演示前提&#xff1a;登录单机模式的 mongodb 服务器命令登录【admin】数据库的 mongodb 客户端命令登录【test】数据库的 mongodb 客户端命令 删除文档语法格式两个变体版本&#xff1a;1、remove&#xff1a;根据【name】字段删除一条文档2、deleteOne&…

Three.js--》探寻Cannon.js构建震撼的3D物理交互体验(一)

我们用three.js可以绘制出各种酷炫的画面&#xff0c;但是当我们想要一个更加真实的物理效果的话&#xff0c;这个时候我们就需要一个物理的库&#xff0c;接下来我们就讲解一下今天要学习的canon&#xff0c;它可以给我们提供一个更加真实的物理效果&#xff0c;像物体的张力、…

linux安装mysql5.7

linux安装mysql5.7 一、下载mysql5.7二、解压包介绍三、上传包到linux四、卸载mariadb五、安装mysql六、修改权限七、启动mysql八、使用过navicat创作不易&#xff0c;笔记不易&#xff0c;如觉不错&#xff0c;请三连&#xff0c;谢谢~~ 一、下载mysql5.7 去mysql官方下载&am…

kafka启动命令、查看topic命令、查看消息内容命令

kafka启动命令 cd /opt/kafka/kafka_2.12-3.5.1/bin ./kafka-server-start.sh ../config/server.properties Windows环境下用kafka Tool 连不上虚拟机的broker报了unable to connect broker 0&#xff0c; 但是zookeeper可以连接上 server.properties的listeners改为listene…

数据结构从入门到精通——链表

链表 前言一、链表1.1 链表的概念及结构1.2 链表的分类1.3 链表的实现1.4 链表面试题1.5 双向链表的实现 二、顺序表和链表的区别三、单项链表实现具体代码text.htext.cmain.c单链表的打印空间的开辟链表的头插、尾插链表的头删、尾删链表中元素的查找链表在指定位置之前、之后…

力扣 分割回文串

输出的是不同的分割方案 class Solution { public:vector<vector<bool>>flag;vector<string>ans;vector<vector<string>>nums;void dfs(string &s,int i){int ns.size();if(in){i表示s长度&#xff0c;等于即全部分割完毕nums.push_back(ans…

大文件传输之udp收发包错误如何解决

数据传输的速度和稳定性对于企业运营至关重要。UDP&#xff08;用户数据报协议&#xff09;作为一种无连接的网络协议&#xff0c;以其高效的数据传输能力在实时应用中得到了广泛应用。然而&#xff0c;UDP的不可靠性也带来了收发包错误的问题&#xff0c;这在需要高数据完整性…

【MGR】MySQL Group Replication快速开始

目录 17.2 Getting Started 17.2.1 Deploying Group Replication in Single-Primary Mode 17.2.1.1 Deploying Instances for Group Replication 17.2.1.2 Configuring an Instance for Group Replication Storage Engines Replication Framework Group Replication Sett…

【好书推荐-第七期】《RTC程序设计:实时音视频权威指南》(音视频开发必看!)

&#x1f60e; 作者介绍&#xff1a;我是程序员洲洲&#xff0c;一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主、前后端开发、人工智能研究生。公粽号&#xff1a;洲与AI。 &#x1f388; 本文专栏&#xff1a;本文收录…

物联网边缘计算云边协同

文章目录 一、物联网云边协同1.IoT云边协同设计2.物联网平台设计3.物联网平台实现 二、部署环境1.节点配置2.版本信息 三、IoT云边协同部署1.部署Kubernetes集群2.部署KubeEdge3.部署ThingsBoard集群4.部署Node-RED边缘网关4.1.边缘网关功能4.2.部署EMQX4.2.部署Node-RED 5.配置…

【sgCollapseBtn】自定义组件:底部折叠/展开按钮

特性&#xff1a; 支持自定义折叠状态支持自定义标签名称 sgCollapseBtn源码 <template><div :class"$options.name" click"show !show" :placement"placement"><div class"collapse-btns"><div class"c…

YOLOv9独家原创改进|加入幽灵卷积Ghost Convolution模块,轻量化!

专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;主力高效涨点&#xff01;&#xff01;&#xff01; 一、论文摘要 由于内存和计算资源有限&#xff0c;在嵌入式设备上部署卷积神经网络是困难的。特征图中的冗余是那些成功的细胞神经网络的一个重要特征…

Linux基础命令[10]-cmp

文章目录 1. cmp 命令说明2. cmp 命令语法3. cmp 命令示例3.1 不加参数3.2 -b&#xff08;显示不同的字节&#xff09;3.3 -i&#xff08;跳过字节&#xff09;3.4 -l&#xff08;显示所有不同&#xff09;3.5 -n&#xff08;比较n个字节&#xff09;3.6 -s&#xff08;不显示信…

深圳牵头打造鸿蒙原生应用软件生态 | 百能云芯

深圳市工业和信息化局、深圳市政务服务和数据管理局于3月3日联合印发了《深圳市支持开源鸿蒙原生应用发展2024年行动计划》。这一计划旨在通过政策引导、市场推动、社会协同的方式&#xff0c;将深圳打造成一个鸿蒙原生应用软件生态的中心&#xff0c;推动鸿蒙系统在当地的发展…

Spring Boot2.2.4版本启动项目时,访问登录接口显示页面不存在

问题触发场景&#xff1a;IDEA 2023.3.4 SpringBoot 2.2.4 上面4张图片分别是项目结构、Spring Boot启动配置、SpringMVC配置和页面展示在项目中存放的位置&#xff0c;表面上看上去没有太大问题&#xff0c;项目应该会达到预期结果&#xff0c;但是bug总是在不经意间出现&…

HarmonyOS端云体化开发—创建端云一体化开发工程

云开发工程模板 DevEco Studio目前提供了两种云开发工程模板&#xff1a;通用云开发模板和商城模板。您可根据工程向导轻松创建端云一体化开发工程&#xff0c;并自动生成对应的代码和资源模板。在创建端云一体化开发工程前&#xff0c;请提前了解云开发工程模板的相关信息。 …

基于 Vue3打造前台+中台通用提效解决方案(下)

47、通用组件 - 倒计时组件 特惠部分存在一个倒计时的功能,所以我们需要先处理对应的倒计时模块,并把它处理成一个通用组件。 那么对于倒计时模块我们又应该如何进行处理呢? 所谓倒计时,其实更多的是一个时间的处理,那么对于时间的处理,此时我们就需要使用到一个第三方…

Kubernetes(k8s第一部分)

这个技术一定会成为以后企业技术的标准 尙硅谷的王阳这个部分这个讲的特别好&#xff0c;可以自己去看 1&#xff0c;发展经历 阿里云iaas Infrastructure as a Service 平台及服务paas新浪云 platform as a service(号称免运维)&#xff08;docker是下一代的标准&#x…