Search

Balanced Binary Tree

Given a binary tree, determine if it is height-balanced.

For this problem, a height-balanced binary tree is defined as:

a binary tree in which the left and right subtrees of every node differ in height by no more than 1.

Example 1:


Example 1:

Input: root = [3,9,20,null,null,15,7]
Output: true

Example 2:



Input: root = [1,2,2,3,3,null,null,4,4]
Output: false

Example 3:

Input: root = []
Output: true

Constraints:

  • The number of nodes in the tree is in the range [0, 5000].

  • -104 <= Node.val <= 104


class Solution { boolean isBalanced = true; public boolean isBalanced(TreeNode root) { helper(root); return isBalanced; } private int helper(TreeNode node) { if (node == null) return 0; int left = helper(node.left); int right = helper(node.right); if (Math.abs(left - right) > 1) { isBalanced = false; } return Math.max(left, right) + 1; } }

16 views0 comments

Recent Posts

See All

A string s is called good if there are no two different characters in s that have the same frequency. Given a string s, return the minimum number of characters you need to delete to make s good. The f

The numeric value of a lowercase character is defined as its position (1-indexed) in the alphabet, so the numeric value of a is 1, the numeric value of b is 2, the numeric value of c is 3, and so on.