首页 > 其他分享 >[LeetCode][110]平衡二叉树

[LeetCode][110]平衡二叉树

时间:2024-03-13 12:33:50浏览次数:24  
标签:子树 return 110 深度 二叉树 root LeetCode maxDepth

题目

110.平衡二叉树

给定一个二叉树,判断它是否是平衡二叉树。

  • 示例 1:
    在这里插入图片描述

输入:root = [3,9,20,null,null,15,7]
输出:true

  • 示例 2:
    在这里插入图片描述

输入:root = [1,2,2,3,3,null,null,4,4]
输出:false

  • 示例 3:

输入:root = []
输出:true

  • 提示:
    树中的节点数在范围 [0, 5000] 内
    -104 <= Node.val <= 104

解法1:自顶向下由最大深度进行计算

  1. 平衡二叉树是指该树所有节点的左右子树的深度相差不超过 1
  2. 很容易联想到使用二叉树的最大深度计算方法,计算左右子树的深度差并判断,然后再计算子树的左右子树的深度差,再进行判断,不断递归

class Solution {
public:
    int maxDepth(TreeNode* root){
        if(!root) return 0;
        return max(maxDepth(root->left), maxDepth(root->right))+1;
    }
    bool isBalanced(TreeNode* root) {
        if(!root) return true;
        return isBalanced(root->left) && isBalanced(root->right) && abs(maxDepth(root->left)-maxDepth(root->right)) <= 1;
    }
};

解法2:剪枝——后序遍历

  1. 解法1 很容易想到,但是缺点是重复计算比较多,因为需要计算子树的高度差,子树的子树的高度差
  2. 如果从底至顶进行遍历,当发现左右子树高度差大于1 时,立刻返回,可减少不必要的重复操作
  3. 如果高度差符合要求,就返回当前的最大深度即可

class Solution {
public:
    int postOrder_maxDepth(TreeNode* root){//后序遍历最大深度
        if(!root) return 0;
        int leftDepth = postOrder_maxDepth(root->left);
        if(leftDepth == -1) return -1;
        int rightDepth = postOrder_maxDepth(root->right);
        if(rightDepth == -1) return -1;
        return abs(leftDepth-rightDepth)<=1 ? max(leftDepth, rightDepth)+1 : -1;
    }
    bool isBalanced(TreeNode* root) {
        return postOrder_maxDepth(root) != -1;
    }
};

标签:子树,return,110,深度,二叉树,root,LeetCode,maxDepth
From: https://blog.csdn.net/Beihai_Van/article/details/136676275

相关文章

  • LeetCode每日一题[C++]-2864.最大二进制奇数(贪心)
    题目描述给你一个 二进制 字符串 s ,其中至少包含一个 '1' 。你必须按某种方式 重新排列 字符串中的位,使得到的二进制数字是可以由该组合生成的 最大二进制奇数 。以字符串形式,表示并返回可以由给定组合生成的最大二进制奇数。注意 返回的结果字符串 可以 含前......
  • LeetCode题练习与总结:最长有效括号
    一、题目给你一个只包含'(' 和')' 的字符串,找出最长有效(格式正确且连续)括号子串的长度。二、解题思路1.初始化一个栈和一个变量maxLen来记录最长有效括号子串的长度。栈用于存储左括号的索引,maxLen初始化为0。2.遍历字符串s中的每个字符。对于每个字符,执行以下......
  • [LeetCode][LCR174] 寻找二叉搜索树中的目标节点
    题目LCR174.寻找二叉搜索树中的目标节点某公司组织架构以二叉搜索树形式记录,节点值为处于该职位的员工编号。请返回第cnt大的员工编号。示例1:输入:root=[7,3,9,1,5],cnt=27/\39/\15输出:7示例2:输......
  • 代码随想录算法训练营day21 | leetcode 530. 二叉搜索树的最小绝对差、501. 二叉搜索
    目录题目链接:530.二叉搜索树的最小绝对差-简单题目链接:501.二叉搜索树中的众数-简单题目链接:236.二叉树的最近公共祖先-中等题目链接:530.二叉搜索树的最小绝对差-简单题目描述:给你一个二叉搜索树的根节点root,返回树中任意两不同节点值之间的最小差值。差值是一个正数,......
  • LeetCode[题解] 1261. 在受污染的二叉树中查找元素
    首先我们看原题给出一个满足下述规则的二叉树:root.val==0如果 treeNode.val==x 且 treeNode.left!=null,那么 treeNode.left.val==2*x+1如果 treeNode.val==x 且 treeNode.right!=null,那么 treeNode.right.val==2*x+2现在这个二叉树受到「污......
  • 2024-03-12 leetcode写题记录
    目录2024-03-12leetcode写题记录160.相交链表题目链接题意解法解法一解法二2024-03-12leetcode写题记录160.相交链表题目链接160.相交链表题意给你两个单链表的头节点\(headA\)和\(headB\),请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回\(nu......
  • leetcode160.链表相交
    160.相交链表 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。图示两个链表在节点 c1 开始相交:题目数据 保证 整个链式结构中不存在环。注意,函数返回结果后,链表必须 保持其原始结......
  • 2024-03-11 leetcode写题记录
    目录2024-03-11leetcode写题记录206.反转链表题目链接题意解法876.链表的中间结点题目链接题意解法2024-03-11leetcode写题记录206.反转链表题目链接206.反转链表题意给你单链表的头节点head,请你反转链表,并返回反转后的链表。解法链表反转板子题,特殊处理下一个点......
  • 代随想录 第十八天 | ● 513.找树左下角的值 ● 112. 路径总和 113.路径总和ii ● 10
    leetcode:513.找树左下角的值-力扣(LeetCode)思路:是找最深左下角的值,不是找左节点最深的值!!遍历深度,判断最大深度,存储后再与下一个相同深度的比较,先左后右,也就是从左到右的顺序来判断的,所以能找到树下左下角的值classSolution{intmaxdepth=0;intresult=0;......
  • Leetcode.19. 删除链表的倒数第 N 个结点
    给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。示例1:输入:head=[1,2,3,4,5],n=2输出:[1,2,3,5]示例2:输入:head=[1],n=1输出:[]示例3:输入:head=[1,2],n=1输出:[1] 提示:链表中结点的数目为 sz1<=sz<=300<=Node.val<=100......