【数据结构_10】二叉树(2)

一、根据树的遍历结果还原树

紧接着(1),我们继续来讨论:如果给了树的遍历结果,我们能否把这个树给还原出来呢?

如果只给一种遍历结果,那么我们无法对树进行还原。

只有给了我们先序+中序,或者后序+中序这两种情况的遍历结果,我们才可以得到树的结果。

*这里不考虑层序的问题,这样的问题是不考层序的。

(1)如果给了先序遍历和中序遍历

1.先序遍历的第一个元素就是根节点

2.在中序遍历中,左子树就在根节点左侧,右子树就在根节点右侧,拿着根节点E,在中序结果中进行查找。

(2)如果给了后序遍历和中序遍历

1.取出后序遍历的最后一个元素,那就是树的根节点

2.拿着根节点在中序中进行查找,查找规则:在中序遍历中,左子树就在根节点左侧,右子树就在根节点右侧,拿着根节点E,在中序结果中进行查找。

3.进行左右子树的还原

*总而言之,根据前序遍历后序遍历中序遍历进行树的还原实质上仅仅是考察这三个知识点:

1.先序的第一个元素,就是根节点(后序也是类似,最后一个元素是根节点)

2.先序中根节点左侧的内容就是左子树的中序结果,右侧内容就是右子树的中序结果

3.先序中,如果明确了根节点和子树范围,此时,子树范围对应的内容就是子树的先序结果(后序也是类似,子树对应的内容就是子树的后序结果)

二、求树的节点个数

java 复制代码
    //根据递归求树的节点个数
    public static int size(Node root){
        if(root == null){
            return 0;
        }
        int leftsize = size(root.left);
        int rightsize = size(root.right);
        return 1+leftsize+rightsize;

    }

三、根据递归求叶子节点的个数

java 复制代码
    public static int getLeafSize(Node root){
        if(root == null){
            return 0;
        }

        if(root.left == null && root.right == null){
            return 1;
        }
        return getLeafSize(root.left)+getLeafSize(root.right);
    }

三、 求二叉树第 k 层节点的个数

java 复制代码
    public static int getLevelNodeCount(int k ,Node root){
        //如果输入的k值小于1 或者 树为空 就返回0
        if(k<1 || root == null){
            return 0;
        }
        if(k==1){
            return 1;
        }
        return getLeafSize(root.right)+getLeafSize(root.left);
    }

思路:如果我们想要获得第k层节点的个数,如果k<1,这是非法的输入,如果k=1,也就是求第一层节点的个数,而非空的树第一层的节点个数也就是1。如果k>1,求第k层节点的个数,我们可以将这个问题转化为求左子树k-1层节点的个数+右子树k-1层的节点个数

四、求二叉树的高度

高度/深度也就是所要求的二叉树中,从根节点出发到任意节点,路径的最大长度。用递归的方式来求解,也就是要求A这个树的高度= max(B的高度,C的高度)+1

java 复制代码
    //求二叉树的深度
    public static int getHeight(Node root ){
        if(root == null){
            return 0;
        }
        return 1+(Math.max(getHeight(root.left),getHeight(root.right)));

    }

五、检测值为value的元素是否存在

存在返回val所在节点的引用,不存在就返回null。首先判定根节点是不是val,如果是,就直接返回该根节点,如果不是,继续递归在左子树中找,如果也没找到,就继续递归在右子树中进行查找。

java 复制代码
    //检测值为val的元素是否存在
    public static Node find(Node root,String val){
        if(root== null){
            return null;
        }
        if(root.val.equals(val)){
            return root;
        }
        //在左子树中进行查找
        Node findResult = find(root.left,val);
        if(findResult != null){
            return  findResult;
        }
        return find(root.right,val);
    }

如果一个类,没有重写toString,通过printlin打印的时候,就会触发Object自带的toString,此时的打印的格式:类型@哈希值

相关推荐
挺菜的26 分钟前
【算法刷题记录(简单题)003】统计大写字母个数(java代码实现)
java·数据结构·算法
2401_858286111 小时前
125.【C语言】数据结构之归并排序递归解法
c语言·开发语言·数据结构·算法·排序算法·归并排序
双叶8362 小时前
(C++)学生管理系统(正式版)(map数组的应用)(string应用)(引用)(文件储存的应用)(C++教学)(C++项目)
c语言·开发语言·数据结构·c++
学不动CV了5 小时前
数据结构---链表结构体、指针深入理解(三)
c语言·arm开发·数据结构·stm32·单片机·链表
算法_小学生7 小时前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
Wo3Shi4七9 小时前
哈希冲突
数据结构·算法·go
V我五十买鸡腿10 小时前
顺序栈和链式栈
c语言·数据结构·笔记·算法
七灵微11 小时前
数据结构实验习题
数据结构
杰克尼1 天前
BM5 合并k个已排序的链表
数据结构·算法·链表
xiaolang_8616_wjl1 天前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20