检查是否二分搜索树
//判断该二叉树是否是一颗二分搜索树
public boolean isBST(){
ArrayList<K> keys=new ArrayList<>();
inOrder(root,keys);
for(int i=1;i<keys.size();i++)
if(keys.get(i-1).compareTo(keys.get(i))>0)
return false;
return true;
}
private void inOrder(Node node,ArrayList<K> keys){
if(node == null)
return ;
inOrder(node.left, keys);
keys.add(node.key);
inOrder(node.right, keys);
}
检查是否平衡二叉树
判断左右两树只差是否小于1 大于1就不是平衡树
if(Math.abs(balanceFactor) >1)
return false;
return isBlanced(node.left) && isBlanced(node.right);
//判断该二叉树是否是一颗平衡二叉树
public boolean isBalanced(){
return isBlanced(root);
}
//判断以node为根的二叉树是否是一颗二叉树,递归算法
private boolean isBlanced(Node node){
if(node ==null)
return true;
int balanceFactor=getBalanceFactor(node);
if(Math.abs(balanceFactor) >1)
return false;
return isBlanced(node.left) && isBlanced(node.right);
}
检查是否是二分搜索树、检查是否平衡二叉树&spm=1001.2101.3001.5002&articleId=87876314&d=1&t=3&u=348d4596346740f885396ce1ba6a5842)
2117

被折叠的 条评论
为什么被折叠?



