zoukankan      html  css  js  c++  java
  • LeetCode 572

    https://leetcode-cn.com/problems/subtree-of-another-tree/

    我们需要借助一个helper方法,这个思想就是双递归,即判断每个大树的节点和小树的根节点的值是否相等,如果相同就进入子树判断方法。否则就在大树节点的左节点和右节点查找。

    helper方法中,如果小树为空大树不为空或者两个值不相等,就返回false,如果两个都为空才返回true,否则就继续递归寻找左子树和右子树。

    /**
     * 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;
     *     }
     * }
     */
    class Solution {
        public boolean isSubtree(TreeNode s, TreeNode t) {
            if(s == null){
                return false;
            }
            boolean flag = false;
            if(s.val == t.val){
                flag = helper(s.left,t.left) && helper(s.right, t.right);
            }
            return flag?flag:isSubtree(s.left,t) || isSubtree(s.right,t);
        }
    
        private boolean helper (TreeNode s, TreeNode t){
            if(t == null){
                if(s != null){
                    return false;
                }
                return true;
            }
            if(s == null || s.val != t.val){
                return false;
            }
            return helper(s.left,t.left)&&helper(s.right,t.right);
        }
    }
  • 相关阅读:
    [手游新项目历程]-36- error: stray ‘357’ in program
    广告学(一)
    VMware的Unity模式
    poj3709
    poj1849
    bzoj2007
    bzoj3209
    bzoj2466,poj1222
    bzoj1016
    bzoj2186
  • 原文地址:https://www.cnblogs.com/ZJPaang/p/12842199.html
Copyright © 2011-2022 走看看