二叉树的直径
data:image/s3,"s3://crabby-images/e726d/e726d492ca5c6dcfaccb97981217bbc0cacb006c" alt="在这里插入图片描述"
class Solution {
public class Info{
public int height;
public int maxPath;
public Info(int a,int b){
height=a;
maxPath=b;
}
}
public Info process(TreeNode x){
if(x==null)return null;
Info leftInfo=process(x.left);
Info rightInfo=process(x.right);
int height=0,maxPath=0;
height=Math.max((leftInfo==null?0:leftInfo.height),(rightInfo==null?0:rightInfo.height))+1;
maxPath=(leftInfo==null?0:leftInfo.height)+(rightInfo==null?0:rightInfo.height);
maxPath=Math.max(maxPath,Math.max((leftInfo==null?0:leftInfo.maxPath),(rightInfo==null?0:rightInfo.maxPath)));
return new Info(height,maxPath);
}
public int diameterOfBinaryTree(TreeNode root) {
return process(root).maxPath;
}
}
data:image/s3,"s3://crabby-images/7566d/7566d129e261186b1bdeb8b77d95ed1e7eecf857" alt="在这里插入图片描述"
二叉树的坡度
data:image/s3,"s3://crabby-images/35382/35382758b90660574693995a991ec332bdc89e6c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/fdf58/fdf58c4a3c335b804ff2d3a8d42e45504222a9c9" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c5e50/c5e50c3b82cfa46b7f1b44e0ce5424214c481e52" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/27322/273224b8f2d6b4a9e498cdb58c78c1fa1642cf58" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/1094d/1094d3ea609b8876b5a1285feef9f9403a34fcbc" alt="在这里插入图片描述"
二叉搜索树的最近公共祖先
data:image/s3,"s3://crabby-images/fd091/fd091e5cf8448b92c6f8d5e9e99c9d90b0bf7c83" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/a4ac5/a4ac53b6f5365f4459bc28936974c548d5052fc1" alt="在这里插入图片描述"
class Solution {
public class Info{
public boolean isFindP;
public boolean isFindQ;
public TreeNode ancestor;
public Info(boolean a,boolean b,TreeNode c){
isFindP=a;
isFindQ=b;
ancestor=c;
}
}
public Info process(TreeNode x,TreeNode p,TreeNode q){
if(x==null){
return null;
}
Info leftInfo=process(x.left,p,q);
Info rightInfo=process(x.right,p,q);
boolean isFindP=false;
boolean isFindQ=false;
TreeNode ancestor=null;
isFindP=(leftInfo==null?false:leftInfo.isFindP)|(rightInfo==null?false:rightInfo.isFindP)|(x==p);
isFindQ=(leftInfo==null?false:leftInfo.isFindQ)|(rightInfo==null?false:rightInfo.isFindQ)|(x==q);
if(leftInfo!=null&&leftInfo.isFindP&&leftInfo.isFindQ){
ancestor=leftInfo.ancestor;
}
if(rightInfo!=null&&rightInfo.isFindP&&rightInfo.isFindQ){
ancestor=rightInfo.ancestor;
}
if(leftInfo!=null&&rightInfo!=null&&leftInfo.isFindP&&rightInfo.isFindQ){
ancestor=x;
}
if(leftInfo!=null&&rightInfo!=null&&leftInfo.isFindQ&&rightInfo.isFindP){
ancestor=x;
}
if(leftInfo!=null&&leftInfo.isFindP&&x==q){
ancestor=x;
}
if(leftInfo!=null&&leftInfo.isFindQ&&x==p){
ancestor=x;
}
if(rightInfo!=null&&rightInfo.isFindP&&x==q){
ancestor=x;
}
if(rightInfo!=null&&rightInfo.isFindQ&&x==p){
ancestor=x;
}
return new Info(isFindP,isFindQ,ancestor);
}
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
return process(root,p,q).ancestor;
}
}
data:image/s3,"s3://crabby-images/5ea58/5ea58dc5e8efb473c958acaff4d83ede2260d872" alt="在这里插入图片描述"
二叉树的最近公共祖先
data:image/s3,"s3://crabby-images/77440/774406fb5b354fd677b2fd7da10641f39b4676e4" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/86868/86868cf3cf4bbc9d75b231fd750bc15b5678b25d" alt="在这里插入图片描述"
class Solution {
public class Info{
boolean isFindP;
boolean isFindQ;
TreeNode ancestor;
public Info(boolean a,boolean b,TreeNode c){
isFindP=a;
isFindQ=b;
ancestor=c;
}
}
public Info process(TreeNode x,TreeNode p,TreeNode q){
if(x==null){
return new Info(false,false,null);
}
Info leftInfo=process(x.left,p,q);
Info rightInfo=process(x.right,p,q);
boolean isFindP=false;
boolean isFindQ=false;
TreeNode ancestor=null;
isFindP=(leftInfo==null?false:leftInfo.isFindP)|(rightInfo==null?false:rightInfo.isFindP)|(x==p);
isFindQ=(leftInfo==null?false:leftInfo.isFindQ)|(rightInfo==null?false:rightInfo.isFindQ)|(x==q);
if(leftInfo!=null&&leftInfo.isFindP&&leftInfo.isFindQ){
ancestor=leftInfo.ancestor;
}
if(rightInfo!=null&&rightInfo.isFindP&&rightInfo.isFindQ){
ancestor=rightInfo.ancestor;
}
if(leftInfo!=null&&rightInfo!=null&&leftInfo.isFindP&&rightInfo.isFindQ){
ancestor=x;
}
if(leftInfo!=null&&rightInfo!=null&&leftInfo.isFindQ&&rightInfo.isFindP){
ancestor=x;
}
if(leftInfo!=null&&leftInfo.isFindP&&x==q){
ancestor=x;
}
if(leftInfo!=null&&leftInfo.isFindQ&&x==p){
ancestor=x;
}
if(rightInfo!=null&&rightInfo.isFindP&&x==q){
ancestor=x;
}
if(rightInfo!=null&&rightInfo.isFindQ&&x==p){
ancestor=x;
}
return new Info(isFindP,isFindQ,ancestor);
}
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
return process(root,p,q).ancestor;
}
}
data:image/s3,"s3://crabby-images/51461/51461a47904d1b68619a360131097ee1d459bc9d" alt="在这里插入图片描述"
检查平衡性
data:image/s3,"s3://crabby-images/d9804/d9804e58dbf63a0c055642e88c4c414ac804550a" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/a8511/a8511e49a3afb6b8af362605b312790268679c01" alt="在这里插入图片描述"
class Solution {
public class Info{
public boolean isBalanced;
public int height;
public Info(boolean a,int b){
isBalanced=a;
height=b;
}
}
public Info process(TreeNode x){
if(x==null){
return new Info(true,0);
}
Info leftInfo=process(x.left);
Info rightInfo=process(x.right);
int height=0;
boolean isBalanced=false;
height=Math.max((leftInfo==null?0:leftInfo.height),(rightInfo==null?0:rightInfo.height))+1;
if((leftInfo==null?true:leftInfo.isBalanced)&&
(rightInfo==null?true:rightInfo.isBalanced)&&
Math.abs((leftInfo==null?0:leftInfo.height)-(rightInfo==null?0:rightInfo.height))<=1){
isBalanced=true;
}
return new Info(isBalanced,height);
}
public boolean isBalanced(TreeNode root) {
Info info=process(root);
return info.isBalanced;
}
}
data:image/s3,"s3://crabby-images/b1d1d/b1d1d3ae8c7b24a929b70877896871e0e1e5d90b" alt="在这里插入图片描述"
|