动态规划

判断一棵树是否是另一棵树的子树

参考了第一个解答

/**
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;
       boolean flag = false;
        if(root1.val == root2.val)
        {
            flag = isSubTree(root1,root2);
        }
        if(!flag)
        {
            flag = HasSubtree(root1.left,root2);
            if(! flag)
            {
                flag = HasSubtree(root1.right,root2);
            }
        }
        return flag;
    }
    public boolean isSubTree(TreeNode root1, TreeNode root2){
        if(root1 == null && root2 != null)
            return false;
        if (root2 == null)
            return true;
        if (root1.val == root2.val)
        {
            return isSubTree(root1.left, root2.left)&&isSubTree(root1.right, root2.right);
        }
        else
            return false;
    }
}
全部评论

相关推荐

05-09 12:23
已编辑
华南理工大学 Java
野猪不是猪🐗:给他装的,双九+有实习的能看的上这种厂我直接吃⑨✌们拿它练练面试愣是给他整出幻觉了
点赞 评论 收藏
分享
ZywOo_求职版:谁问你了....
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务