一文吃透二叉树:前中后序遍历+节点数+树高+叶子节点(含完整源码)

1、前言

二叉树是数据结构核心树形结构,递归实现简洁易懂,是面试、期末考试高频考点。

本文完整手写二叉树创建、递归遍历、统计总结点、叶子节点、树深度高度全套代码。

2、二叉树的完整实现

我们要想实现二叉树,要先定义一下二叉树的结构,二叉树是由一个一个的节点组成的,所以我们定义一下二叉树的每一个节点

2.1定义二叉树的结构,创建节点

2.2连接节点,组成一个二叉树

我们将这些节点彼此链接起来,就快速的构成了一个二叉树,然后返回根节点。

2.3二叉树的前序,中序,后序的遍历

我们解决这种问题,直接记住一个原则:根+子树,一直分,直到子树为NULL,就停止。

一、

前序遍历:根 → 左 → 右(先访问根节点)

中序遍历:左 → 根 → 右(根节点在中间)

后序遍历:左 → 右 → 根(最后访问根节点)

前、中、后,指的是根节点被访问的顺序,左右子树永远先左后右。

二、举个直观例子

现有二叉树结构:

  1. 前序遍历(根左右)

  2. 访问根:A

  3. 遍历左子树B(根B→左D→右E):B D E

  4. 遍历右子树C(根C→右F):C F

✅ 最终序列:A B D E C F

前序的代码实现:

递归展开图

  1. 中序遍历(左根右)

  2. 遍历左子树B(左D→根B→右E):D B E

  3. 访问根:A

  4. 遍历右子树C(左空→根C→右F):C F

✅ 最终序列:D B E A C F

中序的代码实现:

具体的递归展开图和上面的前序的展开图差不多一样,这里就不再写了。

  1. 后序遍历(左右根)

  2. 遍历左子树B(左D→右E→根B):D E B

  3. 遍历右子树C(左空→右F→根C):F C

  4. 访问根:A

✅ 最终序列:D E B F C A

后序代码实现:

2.4二叉树的节点个数

一颗二叉树的节点个数=根节点+左子树的节点总数+右子树的节点总数+1

中止的递归条件

如果当前节点为NULL,说明这颗子树没有节点,返回0,我们简陋写的代码如下

我们在这里用了一个三目操作符,我们先仍进去一个节点是否为NULL,如果为空就返回0,否则继续执行递归,最终返回左右子树节点总数之和。

2.5二叉树的高度

我们想一下,二叉树的高度是不是也可以用递归来解决呢?当只有根节点时,他就返回1,如果不等于1,就继续递归。

思想:一棵树的高度=1(当前根节点)+左子树高度和右子树高度最大的那个值

递归中止条件:如果当前节点为NULL,则这棵树就不存在,返回0;

2.6二叉树的叶子节点的个数

叶子节点=左右孩子都为NULL的节点(没有子节点)

递归核心思路

1.终止条件1:如果当前节点为NULL,没有节点,返回0;

2.终止条件2:如果当前节点的左右孩子都是NULL,返回1;

递归逻辑:否则,整棵树的叶子总数=左子树叶子数+右子树叶子数

3,结果展示

到这里,我们就简单的讲解了二叉树的遍历问题,下一次我们将展开的二叉树的oj题目进行详细的讲解,各位大佬,感觉我写的还可以的,麻烦留下你的小赞赞吧,我们下次再见!

相关推荐
夏日听雨眠4 小时前
linux(线程,线程同步 方法 互斥锁 信号量 条件变量 )
linux·运维·算法
神经网络机器学习智能算法画图绘图4 小时前
基于改进的支持向量机多分类预测研究
算法·支持向量机·分类
阿Y加油吧4 小时前
两道经典算法题复盘:最长有效括号 & 不同路径
算法
迦南的迦 亚索的索4 小时前
机器学习_05_k-means算法
算法·机器学习·kmeans
happymaker06264 小时前
LeetCodeHot100——1.两数之和(详细解答)
java·数据结构·学习·算法
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题 第60题】【JVM篇】第20题:垃圾收集算法和垃圾收集器有什么区别?
java·jvm·算法·面试
@ray3214 小时前
LeetCode Hot 100 — C++ 题解
c++·算法·leetcode
大模型最新论文速读4 小时前
利用异步编程的 future 思想,让 LLM Agent 快 1.44 倍
人工智能·深度学习·算法·机器学习·自然语言处理
Bingorl4 小时前
机器学习之线性回归算法
算法·机器学习·线性回归