[Java/力扣100]判断两棵二叉树是否相同

我希望通过这道题,能进一步了解递归思想和"树是递归定义的"这句话

分析

我们的目的是写一个方法来检验两棵树是否相同

什么叫"两棵树相同"?------相同的位置存在相同的结点

有三种情况:1、两棵树一颗为空一颗不为空------不相同;2、两棵树都是空------相同;3、两个都不是空------不一定

代码

java 复制代码
public class SameBinaryTree {
    public class TreeNode{
        int val;
        TreeNode left;
        TreeNode right;
        TreeNode(){}
        TreeNode(int val){
            this.val = val;
        }
    }
    public boolean isSameTree(TreeNode p, TreeNode q) {
        //两棵树都是空------相同
        if(p == null && q == null){
            return true;
        }
        //两棵树一颗为空一颗不为空------不相同
        if((p == null)&&(q != null) || (p != null) && (q == null)){
            return false;
        }
        //两个都不是空------不一定,所以我们要对其节点值进行判断
        if(p.val != q.val){
            return false;
        }
        //如果这两个根节点相同的话,然后去检查其左子树和右子树是否分别相等
        return isSameTree(p.left,q.left) && isSameTree(p.right,q.right);
    }
}

它是怎样使用递归的

因为树是递归定义的,所以对于二叉树相关的题我们常使用递归思想。

使用递归的两个条件:

1、终止条件

a、两棵树一颗为空一颗不为空------不相同;b、两棵树都是空------相同;

2、调用自身

两棵树是否相同不过就是------"根节点的值是否相同/根节点的左子树是否相同/根节点的右节点是否相同"

我们的方法表示的含义就是"根节点为 参数1 和参数2 的两棵树是否相同"。那么 参数为(参数1.left ,参数2.left)意思就是------"两个根节点的左子树是否相同"

相关推荐
qeen871 小时前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
图码1 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
我星期八休息2 小时前
IT疑难杂症诊疗室:AI时代工程师Superpowers进化论
linux·开发语言·数据结构·人工智能·python·散列表
漂流瓶jz2 小时前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva
你撅嘴真丑3 小时前
map 与 set容器的应用--话题焦点人物
数据结构
生成论实验室3 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
li1670902703 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
代码中介商5 小时前
数据结构开篇:从问题到解决方案
数据结构
AKDreamer_HeXY6 小时前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
Rabitebla7 小时前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法