数据结构:二叉树(初阶)

这篇具有很好参考价值的文章主要介绍了数据结构:二叉树(初阶)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

朋友们、伙计们,我们又见面了,本期来给大家解读一下二叉树方面的相关知识点,如果看完之后对你有一定的启发,那么请留下你的三连,祝大家心想事成!

 

C 语 言 专 栏:C语言:从入门到精通

数据结构专栏:数据结构

个  人  主  页 :stackY、

 

目录

 ​编辑

前言:

1.树的概念及结构

1.1树的概念

1.2 树的相关概念

1.3树的表示

1.4树在实际中的运用

2.二叉树概念及结构 

2.1概念

2.2特殊的二叉树

2.3二叉树的性质

2.4二叉树的存储结构

3.二叉树的顺序结构实现

3.1堆的应用 

1. 堆排序

2. Top-K问题

4.二叉树的链式结构实现

5.二叉树基础OJ练习


前言:

在之前的数据结构中我们学习的是有关线性结构的数据结构,那么在本期我们将会带来树形的数据结构,树形结构通过名字来观察显而易见它的逻辑结构示意图是一种类似现实生活中树的形状和特点,那么一棵树就就会有树根、树枝、树叶,那么二叉树也不例外,在理解二叉树之前呢我们先来了解一下有关树的结构以及概念,话不多说,直接开始:

1.树的概念及结构

1.1树的概念

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因 为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的
        有一个特殊的结点,称为根结点,根节点没有前驱结点。
        除根节点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、……、Tm,其中每            一个集合Ti(1<= i <= m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一            个前驱,可以有0个或多个后继。
        因此,树是递归定义的。

数据结构:二叉树(初阶)

注意:树形结构中,子树之间不能有交集,否则就不是树形结构

数据结构:二叉树(初阶)

1.2 树的相关概念

数据结构:二叉树(初阶)

节点的度:一个节点含有的子树的个数称为该节点的度; 如上图:A的为6、D的为1,B的为0,E的为2。
叶节点或终端节点:度为0的节点称为叶节点; 如上图:B、C、H、I...等节点为叶节点。
非终端节点或分支节点:度不为0的节点; 如上图:D、E、F、G...等节点为分支节点。
双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图:A是B的父节点,E是I和J的父节点。
孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点; 如上图:B是A的孩子节点,H是D的孩子结点。
兄弟节点:具有相同父节点的节点互称为兄弟节点; 如上图:B、C是兄弟节点,K、L、M是兄弟结点。
树的度:一棵树中,最大的节点的度称为树的度; 如上图:树的度为6。
节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推。
树的高度或深度:树中节点的最大层次; 如上图:树的高度为4。
堂兄弟节点:双亲在同一层的节点互为堂兄弟;如上图:H、I互为堂兄弟节点,M、N互为堂兄弟结点。
节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先,F是K、L、M的祖先。
子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙。
森林:由m(m>0)棵互不相交的树的集合称为森林。

1.3树的表示

树结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了,既然保存值域,也要保存结点和结点之间 的关系,实际中树有很多种表示方式如:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法 等。
我们这里就简单的了解其中最常用的孩子兄弟表示法
//树的表示方法
//左孩子右兄弟
typedef int DataType;
struct Node
{
	struct Node* _firstChild1; // 第一个孩子结点
	struct Node* _pNextBrother; // 指向其下一个兄弟结点
	DataType _data; // 结点中的数据域
};

数据结构:二叉树(初阶)

1.4树在实际中的运用

数据结构:二叉树(初阶)

2.二叉树概念及结构 

2.1概念

一棵二叉树是结点的一个有限集合,该集合:
1. 或者为空。
2. 由一个根节点加上两棵别称为左子树和右子树的二叉树组成。
图示:
数据结构:二叉树(初阶)
从上图可以看出:
1. 二叉树不存在度大于2的结点。
2. 二叉树的子树有左右之分次序不能颠倒,因此二叉树是有序树。
注意:对于任意的二叉树都是由以下几种情况复合而成的:

 数据结构:二叉树(初阶)

2.2特殊的二叉树

数据结构:二叉树(初阶)

1. 满二叉树:一个二叉树,如果每一个层的结点数都达到最大值,则这个二叉树就是满二叉树。也就是 说,如果一个二叉树的层数为K,且结点总数是2^k - 1,则它就是满二叉树(每一层都是满的)。
2. 完全二叉树:完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的。对于深度为K 的,有n个结点的二叉树,当且仅当其每一个结点都与深度为K的满二叉树中编号从1至n的结点一一对 应时称之为完全二叉树。 要注意的是满二叉树是一种特殊的完全二叉树(前K-1层必须是满的,最后一层可以不满,但是从左到右必须连续 )。
数据结构:二叉树(初阶)

2.3二叉树的性质

1. 若规定根节点的层数为1,则一棵非空二叉树的第i层上最多有2^(i-1)个结点。
数据结构:二叉树(初阶)
2. 若规定根节点的层数为1,则深度为h的二叉树的最大结点数是2^h-1。
数据结构:二叉树(初阶)

 3.完全二叉树的节点的范围是[ 2^(h-1) , 2^h -1]

完全二叉树的最少的节点个数可以看作是一个高度为h-1的满二叉树再加上一个节点

数据结构:二叉树(初阶)

4. 对任何一棵二叉树, 如果度为0其叶结点个数为N, 度为2的分支结点个数为M,则有N = M+1。
5. 若规定根节点的层数为1,具有n个结点的满二叉树的深度hh= log(n+1)。(log以2为底n+1的对数)。
满二叉树的节点个数为n = 2^h-1,所以满二叉树的高度(深度)为h = log(n+1)

2.4二叉树的存储结构

二叉树一般可以使用两种结构存储,一种顺序结构,一种链式结构。
1. 顺序存储
顺序结构存储就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为不是完全二叉树会有空 间的浪费。而现实中使用中只有堆才会使用数组来存储,二叉树顺 序存储在物理上是一个数组,在逻辑上是一颗二叉树。
数据结构:二叉树(初阶)
2. 链式存储
二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。 通常的方法是链表中每个结点由三个域组成,数据域和左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址 。链式结构又分为二叉链和三叉链,难度也是逐次递增,我们会先从最简单的来学习。
数据结构:二叉树(初阶)

3.二叉树的顺序结构实现

 关于二叉树的顺序结构实现以及堆的概念都在这篇博客中:二叉树的顺序结构--堆

3.1堆的应用 

堆的应用主要有两个方面:

1. 堆排序

2. Top-K问题

大家感兴趣可以去我的这两篇博客看一下,里面都有非常详细的解答:

1. 排序算法:堆排序

2. 堆的应用:Top-K问题

4.二叉树的链式结构实现

二叉树的链式结构是使用链表的方式来实现,每一个节点都有一个左子树和一个右子树,在链式二叉树中我们会学习到链式二叉树的创建方式、求节点个数、树的高度......,具体的实现过程在这篇博客中:数据结构:链式二叉树,感兴趣的老铁可以跳转过去看一看。

5.二叉树基础OJ练习

单值二叉树:https://leetcode.cn/problems/univalued-binary-tree/

检查两个树是否相同:https://leetcode.cn/problems/same-tree/

对称二叉树:https://leetcode.cn/problems/symmetric-tree/

今天的博客就分享到这里,喜欢的老铁留下你的三连,感谢感谢!我们下期再见!! 文章来源地址https://www.toymoban.com/news/detail-471514.html

到了这里,关于数据结构:二叉树(初阶)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构:链式二叉树初阶

    目录 一.链式二叉树的逻辑结构 1.链式二叉树的结点结构体定义 2.链式二叉树逻辑结构 二.链式二叉树的遍历算法 1.前序遍历 2.中序遍历 3.后序遍历  4.层序遍历(二叉树非递归遍历算法) 层序遍历概念: 层序遍历算法实现思路:  层序遍历代码实现: 三.链式二叉树遍历算法的运用

    2024年02月02日
    浏览(43)
  • 初阶数据结构之---二叉树的顺序结构-堆

    今天要讲的堆,不是操作系统虚拟进程地址空间中(malloc,realloc等开空间的位置)的那个堆,而是数据结构中的堆,它们虽然名字相同,却是截然不同的两个概念。堆的底层其实是 完全二叉树 ,如果你问我,完全二叉树是什么。好吧,那我先从树开始讲起,开始我们今天的

    2024年03月14日
    浏览(55)
  • 数据结构初阶--二叉树的顺序结构之堆

    目录 一.堆的概念及结构 1.1.堆的概念 1.2.堆的存储结构 二.堆的功能实现 2.1.堆的定义 2.2.堆的初始化 2.3.堆的销毁 2.4.堆的打印 2.5.堆的插入 向上调整算法 堆的插入 2.6.堆的删除 向下调整算法 堆的删除 2.7.堆的取堆顶元素 2.8.堆的判空 2.9.堆的求堆的大小 三.堆的创建 3.1.向上调

    2024年02月14日
    浏览(42)
  • 数据结构奇妙旅程之二叉树初阶

    ꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好,我是xiaoxie.希望你看完之后,有不足之处请多多谅解,让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如需转载还请通知˶⍤⃝˶ 个人主页:xiaoxieʕ̯

    2024年01月19日
    浏览(62)
  • 【数据结构初阶】八、非线性表里的二叉树(二叉树的实现 -- C语言链式结构)

    ========================================================================= 相关代码gitee自取 : C语言学习日记: 加油努力 (gitee.com)  ========================================================================= 接上期 : 【数据结构初阶】七、非线性表里的二叉树(堆的实现 -- C语言顺序结构)-CSDN博客  ==========

    2024年02月08日
    浏览(48)
  • 【初阶数据结构】树结构与二叉树的基础概念

    君兮_的个人主页 勤时当勉励 岁月不待人 C/C++ 游戏开发 Hello,米娜桑们,这里是君兮_,今天带来数据结构里的重点内容也是在笔试,面试中的常见考点——树与二叉树,其中二叉树又分为很多种,我们先来讲讲基础的内容带大家一步步入门 在介绍二叉树之前,我们得先知道什

    2024年02月08日
    浏览(38)
  • 数据结构初阶之二叉树的详细解析

    个人主页:点我进入主页 专栏分类:C语言初阶      C语言程序设计————KTV       C语言小游戏     C语言进阶 C语言刷题       数据结构初阶    Linux 欢迎大家点赞,评论,收藏。 一起努力,共赴大厂。 目录 1.前言  2.二叉树各个功能代码实现 2.1二叉树结构体 2.2二叉

    2024年02月05日
    浏览(39)
  • 【初阶数据结构】二叉树的几种遍历详解

    君兮_的个人主页 勤时当勉励 岁月不待人 C/C++ 游戏开发 Hello,米娜桑们,这里是君兮_,有了我们之前介绍的树结构与二叉树的基础概念,今天我们来讲讲对二叉树的基本使用——遍历 我们自己先简单链式连接几个结点来创建一个二叉树方便我们之后对遍历的讲解 好了,有了

    2024年02月08日
    浏览(40)
  • C语言数据结构初阶(10)----二叉树的实现

    · CSDN的uu们,大家好。这里是C语言数据结构的第十讲。 · 目标:前路坎坷,披荆斩棘,扶摇直上。 · 博客主页: @姬如祎 · 收录专栏: 数据结构与算法     目录 1. 函数接口一览 2. 函数接口的实现 2.1 BTNode* BuyNode(BTDataType x) 的实现 2.2 BTNode* CreateTree() 的实现  2.3 void

    2023年04月08日
    浏览(43)
  • 数据结构初阶之二叉树性质练习与代码练习

    个人主页:点我进入主页 专栏分类:C语言初阶      C语言程序设计————KTV       C语言小游戏     C语言进阶 C语言刷题       数据结构初阶    Linux 欢迎大家点赞,评论,收藏。 一起努力,共赴大厂。 目录 1.前言 2.性质练习 3.代码练习  3.1单值二叉树 3.2检查两颗树

    2024年02月04日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包