572. 另一棵树的子树

572. 另一棵树的子树

原题

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
 /**
 解题思路
要判断一个树 t 是不是树 s 的子树,那么可以判断 t 是否和树 s 的任意子树相等。那么就转化成 100. Same Tree。 即,这个题的做法就是在 s 的每个子节点上,判断该子节点是否和 t 相等。

判断两个树是否相等的三个条件是与的关系,即:

当前两个树的根节点值相等;
并且,s 的左子树和 t 的左子树相等;
并且,s 的右子树和 t 的右子树相等。
而判断 t 是否为 s 的子树的三个条件是或的关系,即:

当前两棵树相等;
或者,t 是 s 的左子树;
或者,t 是 s 的右子树。
判断 是否是相等的树 与 是否是子树 的代码简直是对称美啊~
  */
class Solution {
    public boolean isSubtree(TreeNode root, TreeNode subRoot) {
        if(root==null&&subRoot==null){
            return true;
        }
        if(root==null||subRoot==null){
            return false;
        }
        //判断当前两棵树相等,还是root左子树包含,还是右子树包含
        return isSametree(root,subRoot)||isSubtree(root.left,subRoot)||isSubtree(root.right,subRoot);
    }

    //判断两棵树是否相等
    public boolean isSametree(TreeNode root,TreeNode subRoot){
        if(root==null&&subRoot==null){
            return true;
        }
        if(root==null||subRoot==null){
            return false;
        }
        return root.val==subRoot.val&&isSametree(root.left,subRoot.left)&&isSametree(root.right,subRoot.right);
    }

}

你可能感兴趣的:(LeetCode刷题,深度优先,数据结构)