动态规划

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

参考了第一个解答

/**
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;
    }
}
全部评论

相关推荐

湫湫湫不会java:先投着吧,大概率找不到实习,没实习的时候再加个项目,然后把个人评价和荣誉奖项删了,赶紧成为八股战神吧,没实习没学历,秋招机会估计不多,把握机会。或者说秋招时间去冲实习,春招冲offer,但是压力会比较大
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-30 18:19
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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