IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 二叉树 基础题解 -> 正文阅读

[数据结构与算法]二叉树 基础题解


这些问题都有一个类TreeNode。

  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;
      }
  }

一.相同的树

给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。(如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的)

思路

采用递归思路,也是深度优先搜索,具体看代码解释便可以懂。

代码

public boolean isSameTree(TreeNode p, TreeNode q) {
		//p,q同时为空节点
        if(p==null&&q==null){
            return true;
        }
        //其中p,q有一个为空一个不为空(那么必然不相等)
        if(p==null||q==null){
            return false;
        }
        //其中有节点的val不相等,那么也就不相等了
        if(p.val!=q.val){
            return false;
        }
        return isSameTree(p.left,q.left)&&isSameTree(p.right,q.right);
    }

二.另一棵树的子树

给你两棵二叉树 root 和 subRoot 。检验 root 中是否包含和 subRoot 具有相同结构和节点值的子树。如果存在,返回 true ;否则,返回 false 。

二叉树 tree 的一棵子树包括 tree 的某个节点和这个节点的所有后代节点。tree 也可以看做它自身的一棵子树。

思路

深度优先暴力解法,需要用到相同的树这个题的代码。

代码

public boolean isSubtree(TreeNode root, TreeNode subRoot) {
		//都是空树,则条件一定成立
        if (root==null&&subRoot==null){
            return true;
        }
        //一个为空一个不为空,那么就不构成子树条件
        if(root==null||subRoot==null){
            return false;
        }
        //设置ret变量,存放判断是否是相同的树
        boolean ret=false;
        if(root.val==subRoot.val){
            ret=isSameTree(root,subRoot);
        }
        //左右递归,只要出现一个子树,那么就条件成立
        return ret||isSubtree(root.left,subRoot)||isSubtree(root.right,subRoot);
    }
    public boolean isSameTree(TreeNode p, TreeNode q) {
        if(p==null&&q==null){
            return true;
        }
        if(p==null||q==null){
            return false;
        }
        if(p.val!=q.val){
            return false;
        }
        return isSameTree(p.left,q.left)&&isSameTree(p.right,q.right);
    }

三.二叉树的最大深度

给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。(说明: 叶子节点是指没有子节点的节点)

思路

依然深度优先搜索,递归遍历,(代码简洁明了,可读性高)

代码

public int maxDepth(TreeNode root) {
		//空树着,则为0
         if(root==null){
            return 0;
        }
        //当左右都为空的时候,那么就是叶子节点了,返回1
        if(root.left==null&&root.right==null){
            return 1;
        }
        //递归记录,左右子树的深度
        int left=maxDepth(root.left);
        int right=maxDepth(root.right);
		//三目运算,保留最大的深度
        return 1+(left>right?left:right);
    }

四.平衡二叉树

给定一个二叉树,判断它是否是高度平衡的二叉树。
本题中,一棵高度平衡二叉树定义为:一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1

思路

自顶向下的深度优先搜索,递归遍历。需要用到***二叉树的最大深度***的代码

代码

public boolean isBalanced(TreeNode root) {
        //空树,一定符合平衡条件
        if(root==null){
            return true;
        }
        //只有一个根节点,左右子树都为空,也符合平衡条件
        if(root.left==null&&root.right==null){
            return true;
        }
        //利用求二叉树的最大深度的代码,求出最大深度
        int left=maxDepth(root.left);
        int right=maxDepth(root.right);
        //出现左右高度差超过1,那么就一定不符合平衡条件了
        if(left-right>1||left-right<-1){
            return false;
        }
        //深度优先遍历
        return isBalanced(root.left)&&isBalanced(root.right);
    }

    public int maxDepth(TreeNode root) {
        if(root==null){
            return 0;
        }
        if(root.left==null&&root.right==null){
            return 1;
        }
        int left=maxDepth(root.left);
        int right=maxDepth(root.right);
        return 1+(left>right?left:right);
    }

五.对称二叉树

  1. 对称二叉树
    给定一个二叉树,检查它是否是镜像对称的。
    在这里插入图片描述

思路

递归遍历,深度优先搜索,看代码中的解释即可。

代码

 public boolean isSymmetric(TreeNode root) {
        if(root==null){
            return true;
        }
        return isMirror(root.left,root.right);
    }

    public boolean isMirror(TreeNode A,TreeNode B){
    	//空树,则符合对称
        if(A==null&&B==null){
            return true;
        }
        //其中一个为空,一个不为空,则一定不满足条件
        if(A==null||B==null){
            return false;
        }
        //对应位置值不相等,则也一定不满足条件
        if(A.val!=B.val){
            return false;
        }
        return isMirror(A.left,B.right)&&isMirror(A.right,B.left);
    }

递归这个思想,我们切记一定不能纵向思考(去寻找递归的结果),要横向思考(寻找递归的公式),这才是这个思想的精髓。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-11-14 21:58:23  更:2021-11-14 21:58:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:09:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码