当前位置: 首页 > article >正文

数据结构-二叉树及其遍历

 🚀欢迎来到我的【数据结构】专栏🚀
  • 🙋我是小蜗,一名在职牛马。
  • 🐒我的博客主页​​​​​​ ➡️ ➡️ 小蜗向前冲的主页
  • 🙏🙏欢迎大家的关注,你们的关注是我创作的最大动力🙏🙏

🌍前言

本篇文章咱们聊聊数据结构中的树,准确的说因该是只说一说二叉树以及相关的三种递归遍历、三种非递归遍历以及层次遍历。

🌍目录

一、二叉树的定义

二、特殊的二叉树

1、满二叉树

2、完全二叉树

三、二叉树的遍历及代码

示例图:

前置准备:

1、先序遍历

🫧规则

🫧代码

2、中序遍历

🫧规则

🫧代码

3、后序遍历

🫧规则

🫧代码

4、层次遍历

🫧规则

🫧代码

最终结果(总结)


一、二叉树的定义

🍃二叉树 (BinaryTree) 是 n (n>0) 个结点所构成的集合,它或为空树(n-0)或为非空树,对于非空树 T:

(1) 有且仅有一个称之为根的结点:

(2) 除根结点以外的其余结点分为两个互不相交的子集 TI 和 T2,分别称为 T 的左子树和右子树,且 T1 和 T2 本身又都是二叉树。
🍃二叉树与树一样具有递归性质,二叉树与树的区别主要有以下两点:

(1) 二叉树每个结点至多只有两棵子树(即二叉树中不存在度大于 2 的结点) ;

(2) 二叉树的子树有左右之分,其次序不能任意颠倒。

二叉树的递归定义表明二叉树或为空,或是由一个根结点加上两棵分别称为左子树和右子树的、互不相交的二叉树组成。由于这两棵子树也是二叉树,则由二叉树的定义,它们也可以是空树。由此,二叉树可以有 5 种基本形态:

二、特殊的二叉树

1、满二叉树

定义:一棵高度为 h,且含有 2^{h}-1个结点的二叉树称为满二叉树。文字不好理解看图!!!

其实就是每一层都含有最多的结点,除叶子结点外每个结点度都为2。

2、完全二叉树

高度为h、有n个结点的二叉树,当且仅当其每个结点都与高度为h的满二叉树中编号为1~n的结点一一对应时,称为完全二叉树。

对比

三、二叉树的遍历及代码

示例图:


http://www.kler.cn/a/396321.html

相关文章:

  • Shell基础2
  • Tessy学习笔记—requirement(需求)的管理
  • 微搭低代码入门05循环
  • 神经网络与Transformer详解
  • 【安全科普】NUMA防火墙诞生记
  • ROS进阶:使用URDF和Xacro构建差速轮式机器人模型
  • 第二十九篇——线性代数:“矩阵”到底怎么用?
  • 【数据结构】双向链表定义与实现
  • linux 工具curl详解
  • 效益登记册效益管理计划
  • 用WordPress需要学习哪些编程知识
  • CentOS 9 配置网卡
  • Dial-insight:利用高质量特定领域数据微调大型语言模型防止灾难性遗忘
  • NPOI 实现Excel模板导出
  • 【miniMax开放平台-注册安全分析报告-无验证方式导致安全隐患】
  • 【Unity Bug 随记】unity version control 报 xx is not in a workspace.
  • 时序数据库TDEngine
  • Day 65 || SPFA、判断负权回路、bellman_ford之单源有限最短路
  • 【leetcode】N皇后 回溯法c++
  • 一文说清libc、glibc、glib的发展和关系
  • 《JavaScript 前端开发》
  • python学习_2.去除字符strip方法
  • CC3学习记录
  • H5页面多个视频如何只同时播放一个?
  • 【idea】更换快捷键
  • 51c大模型~合集42