树的子结构
题目描述
输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
思路
使用递归的方式进行比较,先确认根节点是否符合,再确认左节点是否正确(递归),确认右节点是否正确(递归)
如果第一个值相等,就进入比较每一个值的环节(递归)
public static boolean HasSubtree(TreeNode root1,TreeNode root2) {
Boolean result = false;
if(root1!=null&&root2!=null){
if(root1.val == root2.val){
//查找子结构
result = HasSubtree1(root1,root2);
}
//查找左子树 递归
if(!result){
result = HasSubtree(root1.left,root2);
}
//查找右子树 递归
if(!result){
result = HasSubtree(root1.right,root2);
}
}
return result;
}
//查找子结构
public static boolean HasSubtree1(TreeNode node1,TreeNode node2){
if(node2 == null){
return true;
}
if(node1 == null){
return false;
}
if(node1.val != node2.val){
return false;
}
//递归
return HasSubtree1(node1.left,node2.left)&&HasSubtree1(node1.right,node2.right);
}
本文介绍了一种通过递归方式判断一棵二叉树是否为另一棵二叉树子结构的算法。首先确认根节点是否匹配,然后递归检查左子树和右子树。详细解析了HasSubtree和HasSubtree1两个核心方法的实现过程。
348

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



