数据结构知识点-树与二叉树讲解

本文详细介绍了数据结构中的树和二叉树概念,包括树的术语、二叉树的定义、存储方式(链式存储和顺序存储)以及二叉树的四种遍历方法(前序、中序、后序和层次遍历)。此外,还提供了C语言实现的遍历代码。
摘要由CSDN通过智能技术生成

树与二叉树

1. 什么是树

顾名思义,第一想到的就是路边的树,有树干、树根、树叶,数据结构中的树也是这样延伸过来的,只不过专用名词不一样,如图在这里插入图片描述
关于树的一些专有名词:A 是 B 的父节点,B 是 A 的子节点,D 是 B 的兄弟节点,C 和 D 称为叶子节点,A 为根节点。
树的高度:根节点到叶子节点的最长路径
节点的高度:节点到叶子节点的高度
节点的深度:该节点到根节点的路径,也就是边的数量
树的深度:树从根结点开始往下数,叶子结点所在的最大层数
层:根节点为第一层,依次往下递增。

2. 什么是二叉树

二叉树,就是给树做了一个条件限制,除了叶子结点,其余每个节点有且只有两个子节点(也就是只有两个叉)。
二叉树有两个很重要的形态就是满二叉树和完全二叉树。
满二叉树:叶子节点全都在最底层,除了叶子节点之外,每个节点都有左右两个子节点,这种二叉树就叫作满二叉树。在这里插入图片描述
完全二叉树:叶子节点都在最底下两层 ,最后一层的叶子节点都靠左排列,并且除了最后一层,其他层的节点个数都要达到最大。在这里插入图片描述

3. 二叉树的存储方式

链式存储法:基于指针的链式存储,每个树的节点都是由数据域和两个指针域组成的。数据域用来存储数据,指针域用来存储左右两个子节点。在这里插入图片描述
顺序存储法:顺序存储就是用数组来存储的,虽然不如指针域那么直观,但是存储的方法挺好理解的。根节点存储在下标 i= 1 的位置;左子节点存储在下标i * 2 = 2的位置,右子节点存储在i * 2 + 1 =3的位置。在这里插入图片描述
数组的方式存储不需要开辟额外的指针空间,但是数组需要的内存空间是连续的,如果连续的内存空间不足,就无法进行存储。

4. 二叉树的遍历

有四种遍历的方式,分别为前序遍历、中序遍历、后序遍历、按层遍历。
前序遍历:先遍历根节点、然后遍历左子节点、最后遍历右子节点
在这里插入图片描述
中序遍历:先遍历左子节点,然后是根节点,最后是右子节点

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

easymoneysniper-7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值