0
点赞
收藏
分享

微信扫一扫

剑指Offer刷题 树的子结构


题目描述

输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)

剑指Offer刷题   树的子结构_子节点


剑指Offer刷题   树的子结构_子结构_02


剑指Offer刷题   树的子结构_子树_03

/**
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;

public TreeNode(int val) {
this.val = val;

}

}
*/
public class Solution {
public boolean HasSubtree(TreeNode root1,TreeNode root2) {
if(root1==null||root2==null){
return false;
}

return isSubtree(root1,root2) //root2是否是root1?
||HasSubtree(root1.left,root2) //root2是root1的左子树?
||HasSubtree(root1.right,root2); //root2是root1的右子树?

}

public boolean isSubtree(TreeNode root1,TreeNode root2){

//终止条件:
//当节点 root2 为空:说明树 root2 已匹配完成(越过叶子节点),因此返回 truetrue ;
//当节点 root1为空:说明已经越过树root1 叶子节点,即匹配失败,返回 falsefalse ;
//当节点 root1和 root2的值不同:说明匹配失败,返回 falsefalse ;

if(root2==null){
return true;
}
if(root1==null||root1.val!=root2.val){
return false;
}
return isSubtree(root1.left,root2.left)&&isSubtree(root1.right,root2.right);
}
}


举报

相关推荐

0 条评论