目录
前言
①二叉树前序遍历
②二叉树中序遍历
③二叉树后序遍历
④检查两棵树是否相同
⑤二茶树的最大深度
⑥另一颗树的子树
⑦判断一颗树是否为一颗平衡二叉树
⑧对称二叉树
⑨二叉树镜像
前言
二叉树是笔试面试的重点,如果你对基础不够了解,建议先阅读我的这篇博客回归总结一下
【Java数据结构】挑战全网最细节图解二叉树前、中、后序遍历
①二叉树前序遍历
data:image/s3,"s3://crabby-images/475cf/475cf98b6f1303f257cc0a5a92c6ca112eca7a1d" alt=""
?data:image/s3,"s3://crabby-images/66276/66276b9f5e3759e22177f5053b1bc802427f0e64" alt=""
void preOrderTraversal(TreeNode root){
if(root == null) {
return;
}
System.out.print(root.val+" ");
preOrderTraversal(root.left);
preOrderTraversal(root.right);
}
②二叉树中序遍历
data:image/s3,"s3://crabby-images/f651c/f651c62dcaec6baef64b05c411ceb9ec18fff5f6" alt=""
?data:image/s3,"s3://crabby-images/f34ba/f34ba03246f0f035963f9fcda81cef55cead2370" alt=""
void inOrderTraversal(TreeNode root){
if(root == null) {
return;
}
inOrderTraversal(root.left);
System.out.print(root.val+" ");
inOrderTraversal(root.right);
}
③二叉树后序遍历
data:image/s3,"s3://crabby-images/ebb0c/ebb0ce6d3b1fb156cb45ec82fe5b0a89f86f18e5" alt=""
?data:image/s3,"s3://crabby-images/b0ebc/b0ebc2d6cadc088cc0245830b043664814bfb305" alt=""
void postOrderTraversal(TreeNode root){
if(root == null) {
return;
}
postOrderTraversal(root.left);
postOrderTraversal(root.right);
System.out.print(root.val+" ");
}
④检查两棵树是否相同
data:image/s3,"s3://crabby-images/73ac8/73ac82a571f4dc9c6342c8a026c40f3aa880dbaf" alt=""
data:image/s3,"s3://crabby-images/13c8e/13c8e2632d492932491f05965246485928d9393f" alt=""
data:image/s3,"s3://crabby-images/e3b4f/e3b4fe5dad4af38e5586538448ce34b60b4d70fc" alt=""
public boolean isSameTree(TreeNode p,TreeNode q){
if(p == null && q != null){
return false;
}
if(p != null && q == null){
return false;
}
if(p == null && q ==null){
return true;
}
if(p.val != q.val){
return false;
}
return isSameTree(p.left,q.left) && isSameTree(p.right,q.right);
}
⑤二茶树的最大深度
data:image/s3,"s3://crabby-images/7fecb/7fecbe498e766936912dcd92e42acd2452447235" alt=""
data:image/s3,"s3://crabby-images/ff91b/ff91bffd3211a812aa061dcb54ca44df4f6beabd" alt=""
public int maxDepth(TreeNode root){
if(root == null){
return 0;
}
int leftHeight = maxDepth(root.left);
int rightHeight = maxDepth(root.right);
return Math.abs(leftHeight-rightHeight > 0? leftHeight + 1: rightHeight + 1);
}
⑥另一颗树的子树
data:image/s3,"s3://crabby-images/f7b46/f7b463437b15c3c5d39facf22503b756b84e56b7" alt=""
?data:image/s3,"s3://crabby-images/9e410/9e410f1fe6c58da9feba3d649670438f647c1206" alt=""
public boolean isSameTree(TreeNode p,TreeNode q){
if(p == null && q != null){
return false;
}
if(p != null && q == null){
return false;
}
if(p == null && q ==null){
return true;
}
if(p.val != q.val){
return false;
}
return isSameTree(p.left,q.left) && isSameTree(p.right,q.right);
}
public boolean isSubtree(TreeNode root, TreeNode suBroot){
if(root == null && suBroot == null){
return true;
}
if(isSameTree(root,suBroot)){
return true;
}
if(isSubtree(root.right,suBroot)){
return true;
}
if(isSubtree(root.left,suBroot)){
return true;
}
return false;
}
⑦判断一颗树是否为一颗平衡二叉树
data:image/s3,"s3://crabby-images/6b457/6b4571d95c47359854214daee625b7f871bb8a3a" alt=""
???data:image/s3,"s3://crabby-images/7db44/7db44815c8f0b79220f0ff87c465f208ae629f9a" alt=""
?data:image/s3,"s3://crabby-images/8cd04/8cd042406a396039ca879015eb03b673421052dd" alt=""
?data:image/s3,"s3://crabby-images/e9d55/e9d554a2a7076763c5e555112fa5772a1d66a1bf" alt=""
public int maxDepth(TreeNode root){
if(root == null){
return 0;
}
int leftHeight = maxDepth(root.left);
int rightHeight = maxDepth(root.right);
return Math.abs(leftHeight-rightHeight > 0? leftHeight + 1: rightHeight + 1);
}
public boolean isBalanced(TreeNode root) {
if(root == null) {
return true;
}
int leftHeight = maxDepth(root.left);
int rightHeight = maxDepth(root.right);
return
Math.abs(leftHeight-rightHeight) < 2 && isBalanced(root.left) && isBalanced(root.right);
}
data:image/s3,"s3://crabby-images/f0136/f0136487b9797d0d0823295a5cd6e26c6396e137" alt=""
public int hight(TreeNode root){
if(root == null){
return 0;
}
int leftHeight = hight(root.left);
int rightHeight = hight(root.right);
if(leftHeight >= 0 && rightHeight >= 0 && Math.abs(leftHeight-rightHeight) <= 1){
return Math.max(leftHeight,rightHeight)+1;
}else{
return -1;
}
}
public boolean isBalanced2(TreeNode root) {
return hight(root) >= 0;
}
⑧对称二叉树
data:image/s3,"s3://crabby-images/abc9b/abc9b804b534c3f7c67e534b7c1e7fef06ab7a80" alt=""
data:image/s3,"s3://crabby-images/c1d99/c1d99abcc207da0f3d5ae3a3294c30a2ed954227" alt=""
data:image/s3,"s3://crabby-images/8bd92/8bd925d4c356059f5de197cfa579e14f4267b884" alt=""
public boolean isSymmetricChild(TreeNode leftTree,TreeNode rightTree){
if(leftTree != null && rightTree == null){
return false;
}
if(leftTree == null && rightTree != null){
return false;
}
if(leftTree == null && rightTree == null){
return true;
}
if(leftTree.val != rightTree.val){
return false;
}
return isSymmetricChild(leftTree.left,rightTree.right) &&
isSymmetricChild(leftTree.left,rightTree.right);
}
public boolean isSymmetric(TreeNode root){
if(root == null){
return true;
}
return isSymmetricChild(root.left,root.right);
}
⑨二叉树镜像
data:image/s3,"s3://crabby-images/fe2fc/fe2fc1c22fa65d1a0ff636b50cfeb78e57476dcb" alt=""
data:image/s3,"s3://crabby-images/7f0d0/7f0d07722a92094f9963bc418ce6e09f8e53af79" alt=""
?data:image/s3,"s3://crabby-images/817bc/817bc802631c96323d7aabd2719305942c419c83" alt=""
?data:image/s3,"s3://crabby-images/b2501/b2501fbee0f7c85a8b0645d5da651b87341766f1" alt=""
public TreeNode Mirror(TreeNode pRoot){
if(pRoot == null){
return pRoot;
}
if(pRoot.left == null && pRoot.right == null){
return pRoot;
}
TreeNode tmp = pRoot.left;
pRoot.left = pRoot.right;
pRoot.right = tmp;
if(pRoot.left != null){
Mirror(pRoot.left);
return pRoot;
}
if(pRoot.right != null){
Mirror(pRoot.right);
return pRoot;
}
return pRoot;
}
|