zoukankan      html  css  js  c++  java
  • 572. 另一个树的子树

    给定两个非空二叉树 s 和 t,检验 s 中是否包含和 t 具有相同结构和节点值的子树。s 的一个子树包括 s 的一个节点和这个节点的所有子孙。s 也可以看做它自身的一棵子树。

    示例 1:
    给定的树 s:

    3
    /
    4 5
    /
    1 2
    给定的树 t:

    4
    /
    1 2
    返回 true,因为 t 与 s 的一个子树拥有相同的结构和节点值

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/subtree-of-another-tree

     1 public class SubtreeofAnotherTree {
     2     static class TreeNode {
     3         int val;
     4         TreeNode left;
     5         TreeNode right;
     6         TreeNode(int x) {
     7             val = x;
     8         }
     9     }
    10     //子树必须从叶结点开始,中间某个部分不是子树,转换一下思路,从某个节点s开始,
    11     //跟t的所有结构都一样,那么问题就转换成判断两棵树是否相同
    12     public boolean isSubtree(TreeNode s, TreeNode t) {
    13 /*        if(s == null && t == null) {  //和27-34行效果相同
    14             return true;
    15         }
    16         if(s == null) {
    17             return false;
    18         }
    19         if(t == null) {
    20             return true;
    21         }
    22         boolean result = false;
    23         if(s.val == t.val) {
    24             result = isSameTree(s, t);
    25         }*/
    26         
    27         if(t == null) {
    28             return true;
    29         }
    30         if(s == null) {
    31             return false;
    32         }
    33         boolean result = false;
    34         result = isSameTree(s, t);  //判断是不是同一树
    35         
    36         
    37         if(!result) {  //如果不是,则判断s的左子树是否和t相同
    38             result = isSubtree(s.left, t);
    39         }
    40         if(!result) {  //如果仍不是,则判断s的右子树是否和t相同
    41             result = isSubtree(s.right, t);
    42         }
    43         return result;
    44     }
    45     
    46     //判断两棵树是否是一样
    47     public static boolean isSameTree(TreeNode root1, TreeNode root2) {
    48         if(root1 == null && root2 == null) {  //最后都同时为null则该节点为叶节点,且相同
    49             return true;
    50         }
    51         if(root1 == null || root2 == null) { //其中一个不为null,说明两节点的子节点不同,该节点也就不同
    52             return false;
    53         }
    54         if(root1.val != root2.val) {  //值不同两节点也不同
    55             return false;
    56         }
    57         return isSameTree(root1.left, root2.left) && isSameTree(root1.right, root2.right);
    58     }
    59 }
    无论有多困难,都坚强的抬头挺胸,人生是一场醒悟,不要昨天,不要明天,只要今天。不一样的你我,不一样的心态,不一样的人生,顺其自然吧
  • 相关阅读:
    ORA-28040: No matching authentication protocol
    kettle增量抽取数据--高效抽取方式
    为什么MySQL的索引要使用B+树而不是其它树形结构?比如B树?
    echarts饼图指示线文字换行
    数据库概论
    Java学习笔记
    案例分析
    软件工程作业3
    软件工程作业2
    软件工程作业1
  • 原文地址:https://www.cnblogs.com/xiyangchen/p/11100351.html
Copyright © 2011-2022 走看看