IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 二叉树的基本概念 -> 正文阅读

[数据结构与算法]二叉树的基本概念

前言:

  • 本文介绍 二叉树相关知识。

树的概念

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的

  • 有一个特殊的结点,称为根结点,根节点没有前驱结点.
  • 除根节点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、……、T,其中每一个集合Ti(1<= i<= m)又是一棵结构与树类似的子树。
  • 每棵子树的根结点有且只有一个前驱,可以有0个或多个后继因此,树是递归定义
    在这里插入图片描述在这里插入图片描述

树的相关名词

在这里插入图片描述

孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点; 如上图:B是A的孩子节点

双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图:A是B的父节点

兄弟节点:具有相同父节点的节点互称为兄弟节点; 如上图:B、C是兄弟节点

堂兄弟节点:双亲在同一层的节点互为堂兄弟;如上图:H、I互为兄弟节点

节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先

子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙

森林:由m(m>0)棵互不相交的的集合称为森林 .

结点的度:一个节点含有的子树的个数称为该节点的度; 如上图:A的为6

叶节点或终端节点度为0的节点称为叶节点或者终端结点; 如上图:B、C、H、I…等节点为叶节点

非终端节点或分支节点:与叶结点相反的,度不为0的节点; 如上图:D、E、F、G…等节点为分支节点 。

树的度:一棵树中,最大的节点的度称为树的度; 如上图:A的度6最大,所以树的度为6

节点的层次:考虑可能为空树,一个结点也没有。这里约定根结点为第一层。从根开始定义起,根为第1层,根的子节点为第2层,以此类推;

树的高度或深度:树中节点的最大层次; 如上图:树的高度为4

树的表示

树的表示方法很多:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。我们这里就简单的了解其中最常用的孩子兄弟表示法

typedef int DataType;
struct Node
{
struct Node* _firstChild1; // 第一个孩子结点
struct Node* _pNextBrother; // 指向其下一个兄弟结点
DataType _data; // 结点中的数据域
}

在这里插入图片描述

树的引用

可以发现树的物理结构有限像,我们电脑中的文件系统:
在这里插入图片描述

二叉树

概念

一棵二叉树是结点的一个有限集合,该集合:

  1. 或者为空
  2. 由一个根节点加上两棵别称为左子树和右子树的二叉树组成

在这里插入图片描述

注意:

  1. 二叉树结点的度最大为2
  2. 二叉树的子树有左右之分,因此二叉树是有序树。

二叉树的一些规律

  1. 若规定根节点的层数为1,则一棵非空二叉树的第i层上最多有 2^(i-1)个结点.-----这是一个递增数列求子项问题。

  2. 若规定根节点的层数为1,则深度为h的二叉树的最大结点数是 2^h -1 . ----递增数列求和问题。

  3. 对任何一棵二叉树, 如果度为0其叶结点个数为N0 , 度为2的分支结点个数为N2 ,总是有 N0= N2+1

在这里插入图片描述

  1. 若规定根节点的层数为1,具有n个结点的满二叉树的深度,h= log2(N+1). ----------------2^h-1=N。

  2. 对于具有n个结点的完全二叉树,如果按照从上至下从左至右的数组顺序对所有节点从0开始编号,则对于序号为i的结点有:

    1. 若i>0,i位置节点的双亲序号:(i-1)/2;i=0,i为根节点编号,无双亲节点
    2. 若2i+1<n,左孩子序号:2i+1;2i+1>=n否则无左孩子—下标越界,
    3. 若2i+2<n,右孩子序号:2i+2;2i+2>=n否则无右孩子—下标越界

    ?

二叉树的组成类型

在这里插入图片描述

特殊的二叉树

满二叉树:二叉树的每层达到最大结点数(2^h -1),构成的二叉树为 :满二叉树

完全二叉树:H层的二叉树,前H-1层是满二叉树,第H层可以是也可以不是满二叉树,但是一定按照严格的:下插入左结点,后右结点,进行结点的插入。因此满二叉树是特殊的完全二叉树。

在这里插入图片描述

二叉树的存储

二叉树一般可以使用两种结构存储,一种顺序结构,一种链式结构 .

  • 顺序存储:就是使用数组来存储,只适合表示完全二叉树,因为不是完全二叉树会有空间的浪费。二叉树顺序存储在物理上是一个数组(即内存中连续的存储单元),在逻辑上是一颗二叉树。
    在这里插入图片描述

  • 链式存储:通过左右孩子法来存储二叉树.缺点:不好查找双亲结点。
    在这里插入图片描述
    ?

题目

  1. 某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为( )
    A 不存在这样的二叉树
    B 200
    C 198
    D 199

答案:B。二叉树中,度为0的永远比度为2的多一个。所以叶子结点有 200个,200+199=399,存在该二叉树。

  1. 下列数据结构中,不适合采用顺序存储结构的是( )

    A 非完全二叉树
    B 堆
    C 队列
    D 栈

    答案:A.数组形式一般适合 完全二叉树,不会过多浪费空间,但是非完全会浪费更多。

  2. 在具有 2n 个结点的完全二叉树中,叶子结点个数为( )

    A n
    B n+1
    C n-1
    D n/2

答案 :A. 设度为0的为N0个,度为2的为N2个,完全二次树中可能存在度为1的,因此设为N1;

? N0=N2+1;

2N=N2+N0+N1

2N=2N0-1+N1;

因为N1只能在0和1中取值,且由奇偶规律可以知道,N1必然为1.

2N=2N0,N0=N;

?

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-02-16 13:22:22  更:2022-02-16 13:22:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 17:31:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码