높이 균형은 모든 노드의 서브 트리 간의 높이 차이가 1 이하인 것을 말한다.
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
def isBalanced(root: TreeNode) -> bool:
def check(root):
if not root:
return 0
left = check(root.left)
right = check(root.right)
if left == -1 or right == -1 or abs(left - right) > 1:
return -1
return max(left, right) + 1
return check(root) != -1
좋은 포스팅이다 싶어 들어오면 항상 June님이시네요 ㅋㅋ
높이 균형은 모든 노드의 서브 트리 간의 높이 차이가 1 이하인 것을 말한다.
이 부분 조금 더 명확하게 설명해 주실 수 있나요?