問題描述:
給定乙個二叉樹,判斷它是否是高度平衡的二叉樹。
本題中,一棵高度平衡二叉樹定義為:
乙個二叉樹每個節點 的左右兩個子樹的高度差的絕對值不超過1。示例 1:
給定二叉樹[3,9,20,null,null,15,7]
3返回/ \9 20
/ \
15 7
true
。
示例 2:
給定二叉樹[1,2,2,3,3,null,null,4,4]
1返回/ \2 2
/ \3 3
/ \4 4
false
解題思路:解這種判斷思路,沒有好辦法,就是按照定義去判斷,所以演算法中需要判斷二叉樹高度。
老規矩 先來自己的
public boolean isbalanced(treenode root) else
}public int height(treenode root)else
}
接下來,再來大神的,大神做的執行速度比我的快,遞迴寫的很精妙,不容易一次寫成,需要對題目理解很深才能寫出,一般在毫無參考的時候不好直接想出來。
class solution
int height(treenode root)
}
leetcode 110 平衡二叉樹 平衡二叉樹
leetcode 110 平衡二叉樹 平衡二叉樹要求所有節點的左右子樹的高度差小於1,因此,只需在遍歷的時候返回其左右子樹的深度。definition for a binary tree node.public class treenode treenode int val treenode int...
判斷平衡二叉樹
演算法 樹 平衡二叉樹 平衡二叉樹的概念 左右節點的樹高之差小於1。1.計算節點的高。通過遞迴,求出左右子樹的高度,當前節點的高度,最大的那乙個 1。int getheight treenode root 2.通過遞迴的方法計算左子樹和右子樹的樹高之差是否有小於1的,有就直接返回false.publ...
判斷平衡二叉樹
package com.jsp.tree 判斷是否是平衡二叉樹 author jiangshipan 任何乙個節點 左子樹和右子數高度差小於1 以每乙個節點為頭的樹都是平衡的,則這個樹平衡 可能 1.左樹不平 2.右樹不平 3.左或右高 整棵樹 public class isbalancedtree...