算法与数据结构学习笔记(3):树

一、树(Tree)

树是n个结点的有限集。
(1)特点:

  • 由且仅有一个特定的称为根(Root)的结点。
  • 当n>1时,其余结点可以分为m个互不相交的有限集,其中每一个集合本身又是一棵树(子树(SubTree))。

(2)度、深度、森林等概念

  • 结点拥有的子树数称为结点的度(Degree),度为0的结点称为叶结点(Leaf)或终端结点,度不为0的非终端结点或分支结点。除根结点之外,分支结点也称为内结点。
    -在这里插入图片描述

  • 树的度:是树内各结点的度的最大值,

  • 树的深度:树中结点的最大层次称为树的深度(Depth)或高度

  • 若将树中结点的各子树看成是从左向右是有次序的,不能互换,则称树为有序树,否则为无序树

  • 森林(Forest)是m棵互不相交的树的集合

二、二叉树(Binary Tree)

(1)定义:
n个结点的有限集合,该集合或者为空集,或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树的二叉树组成。

(2)特点:

  • 每个结点最多有两棵子树。所以二叉树的度<=2
  • 左子树和右子树是有顺序的,次序不能颠倒
  • 即使树中某结点只有一棵子树,也要区分它是左子树还是右子树。(就是左偏还是右偏,如图)
    在这里插入图片描述

1.几种特殊的二叉树

1.斜树

所有的结点都只有左子树的二叉树叫左斜树。反之为右斜树。这两种统称为斜树

2.满二叉树

若所有分支结点都存在左子树和右子树,并且所有叶子都在同一层上。
在这里插入图片描述
特点:叶子只能出现最下一层;非叶子结点的度一定是2;在深度相同的二叉树中,满二叉树的结点个数最多,叶子数最多。

3.完全二叉树

满二叉树一定是一棵完全二叉树,反之不一定。
(1)定义:
对于一棵具有n个结点的二叉树按层编号,若编号为i的结点与同样深度的满二叉树中编号i的结点在二叉树中的位置相同。

(1)特点:

  • 叶子结点=只能出现在最下两层。
  • 最下层的叶子一定集中在左部连续位置。
  • 倒数第二层,若有叶子结点,一定都在右部连续位置。
  • 若结点的度为1,则该结点只有左孩子,即不存在只有右子树的情况。
  • 同样结点数的二叉树,完全二叉树的深度最小。

(2)判断是否为完全二叉树的方法:
给每个结点按照满二叉树的结构逐层顺序编号,若编号出现空挡,就说明不是二叉树,否则就是。(6,7没有,但是往下继续编号的时候要从8开始)
在这里插入图片描述

2.二叉树的性质

  • 性质1:在二叉树的第i层至多有2i-1个结点。

  • 性质2:深度为k的二叉树至多有2k-1个结点。

  • 性质3:对任何一棵二叉树T,若其终端结点数为N0,度为2的结点数为N2,则N0=N2+1

  • 性质4:具有n个结点的完全二叉树的深度为[log2n]+1([x]表示不大于x的最大整数)

  • 性质5:若对一棵有n个结点的完全二叉树(深度有性质4可得)的结点安层编号(从1层往下,每层从左到右),对任一结点:

1.若i=1,则结点i是根,无双亲;若i>1,则其双亲是结点[i/2]
2.若2i>n,则结点i无左孩子(结点i为叶子结点);否则其左孩子是结点2i
3.若2i+1>n,则结点i无右孩子;否则其右孩子是结点2i+1

3.二叉树的存储结构

(1)顺序存储结构
顺序存储结构一般只用于完全二叉树(下标就按照满二叉树的编号来,对于没有的结点用^)
在这里插入图片描述

(2)链式存储结构
二叉树的链式存储结构叫二叉链表。
每个结点有一个数据域和两个指针域,如图:
在这里插入图片描述
lchild为指向左孩子的指针,rchild为指向右孩子的指针。
在这里插入图片描述

三、二叉树的遍历

(1)定义:
从根结点触发,按照某种次序依次访问二叉树中的所有结点,使得每个结点被访问一次且仅一次。

(2)二叉树遍历的性质:
1.已知序遍历序列和序遍历序列,可以唯一确定一棵二叉树。
2.已知序遍历序列和序遍历序列,可以唯一确定一棵二叉树。
3.已知序和序遍历序列,不能确定一棵二叉树。
4.但扩展二叉树(每个结点的空指针引出值为#的虚结点)可以只用一个遍历序列确定二叉树
在这里插入图片描述

1.前序遍历

先打印,再递归左和右

规则:先访问根结点,然后前序遍历左子树,再前序遍历右子树。遍历顺序为:ABDGHCEIF

在这里插入图片描述

2.中序遍历

先递归左,再打印,最后递归右
规则:从根结点开始(不是先访问根结点),中序遍历根结点的左子树,然后访问根结点,最后中序遍历右子树,遍历顺序为:GDHBAEICF
在这里插入图片描述

3.后序遍历

先递归左右,再打印
规则:从左到右先叶子后结点的方式遍历访问左右子树,最后访问根结点,遍历顺序为:GHDBIEFCA

在这里插入图片描述

4.层序遍历

从树的第一层开始(即根结点),从上而下遍历,同一层从左向右。遍历顺序为:ABCDEFGHI
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值