LeetCode 110 判断平衡二叉树

Leetcode 110 判断平衡二叉树

给定一颗二叉树,判断该树是否满足平衡条件: 对于任一节点,其左右子树高度相差不超过1

DFS

执行用时:1 ms, 在所有 Java 提交中击败了99.73%的用户
内存消耗:39.8 MB, 在所有 Java 提交中击败了70.51%的用户

class Solution {
    public boolean isBalanced(TreeNode root) {
        //空节点
        if(root==null) {
            return true;
        }
        //叶子节点
        else if(root!=null && root.left==null && root.right==null) {
            return true;
        }
        //非叶子节点
        else {
            return (Math.abs(dfs(root.left)-dfs(root.right))<2) && isBalanced(root.left) && isBalanced(root.right);
        }

    }

    //对于根节点root,返回其左右子树(如果有的话)的高度
    public int dfs(TreeNode root) {
        if(root==null) {
            return 0;
        }
        int leftHeight = dfs(root.left);
        int rightHeight = dfs(root.right);
        return Math.max(leftHeight, rightHeight)+1;
    }

}
posted @   CodeSPA  阅读(69)  评论(0编辑  收藏  举报
编辑推荐:
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
阅读排行:
· “你见过凌晨四点的洛杉矶吗?”--《我们为什么要睡觉》
· 编程神器Trae:当我用上后,才知道自己的创造力被低估了多少
· C# 从零开始使用Layui.Wpf库开发WPF客户端
· C#/.NET/.NET Core技术前沿周刊 | 第 31 期(2025年3.17-3.23)
· 开发的设计和重构,为开发效率服务
点击右上角即可分享
微信分享提示