[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)意思就是------"两个根节点的左子树是否相同"

相关推荐
风一样的航哥19 小时前
LeetCode 2615 等值距离和:前缀和优化O(n)解法深度解析
数据结构·算法·leetcode
khalil102021 小时前
代码随想录算法训练营Day-34动态规划03 | 01背包问题 二维、01背包问题 一维、416. 分割等和子集
数据结构·c++·算法·leetcode·动态规划·背包问题·01背包
空中海1 天前
Redis 从零到精通:9大数据结构 × 11个高频工程实战场景完全手册
数据结构·数据库·redis
地球资源数据云1 天前
1951-2025年中国逐年1千米逐月总降水量区域统计数据集_年表_县
大数据·数据结构·数据库·数据仓库·人工智能
cpp_25011 天前
P2639 [USACO09OCT] Bessie‘s Weight Problem G
数据结构·算法·动态规划·题解·洛谷·背包dp
郝学胜-神的一滴1 天前
[力扣 227] 双栈妙解表达式计算:从思维逻辑到C++实战,吃透反向波兰式底层原理
java·前端·数据结构·c++·算法
菜鸟丁小真1 天前
LeetCode hot100 -131.分割回文串
数据结构·算法·leetcode·知识点总结
数智化精益手记局1 天前
8d报告案例分析:拆解8d报告案例分析的8个步骤,解决生产现场重复发生的质量难题
大数据·数据结构·数据库·人工智能·精益工程
笨笨饿1 天前
66_C语言与微控制器底层开发
linux·c语言·网络·数据结构·算法·机器人·个人开发
AI人工智能+电脑小能手1 天前
【大白话说Java面试题】【Java基础篇】第10题:HashMap中的元素是有序存放的吗
java·开发语言·数据结构·后端·面试·哈希算法·哈希表