二叉数

二叉树定义二叉树(Binary Tree)是n(n>=0)个节点的有限集合,该集合或者为空集(称为空二叉树),或者由一个根节点和两颗互不相交的、分别称为根节点的左子树、右子树的二叉树组成。五种基本形态:空二叉树、只有一个根节点、根节点只有左子树、根节点只有右子树、根节点既有左子树又有右子树。

二叉树的特点

1.每个节点最多有两棵子树,即不存在度大于2的节点。

2.左子树和右子树是有序的,不能随便颠倒。

3.即使树中某个节点只有一棵子树,也要区分是左子树还是右子树。

满二叉树:

深度为k且含有2k-1个节点的二叉树成为满二叉树。


 

完全二叉树:

如果一个有n个节点的二叉树按满二叉树方式自上而下,自左至右对它进行编号,若树中所有节点和满二叉树的1~n编号完全一致,则称该树为完全二叉树。

 

错误示例:

 

二叉树性质:

1.在二叉树的第i层上最多有2 i-1 个节点 。(i>=1)。

2.二叉树中如果深度为k,那么最多有2k-1个节点。(k>=1)。

3.n0=n2+1  n0表示度数为0的节点叶子节点 n2表示度数为2的节点。

4.在完全二叉树中,具有n个节点的完全二叉树的深度为[log2n]+1,其中[log2n]+1是向下取整不大于[log2n]+1的最大整数

5.若对含 n 个结点的完全二叉树从上到下且从左至右进行 1 至 n 的编号,则对完全二叉树中任意一个编号为 i 的结点:

(1) 若 i=1,则该结点是二叉树的根,无双亲, 否则i>1时,编号为 [i/2] (向下取整)的结点为其双亲结点;  

(2) 若 2i>n,则该结点无左孩子,  否则,编号为 2i 的结点为其左孩子结点;

(3) 若 2i+1>n,则该结点无右孩子结点,  否则,编号为2i+1 的结点为其右孩子结点。

7、二叉树的存储

前面分析已知,树用顺序存储结构实现是比较困难的,但是二叉树是一种特殊的树,因此完全可以用顺序存储结构来描述其关系。

 


其双亲、孩子、兄弟的关系可以用二叉树的性质分析得到!!!!!!

顺序存储结构一般只用于完全二叉树否则会造成空间浪费。

 

二叉树的链式存储结构:二叉链表左右孩子,三叉链表左右孩子带双亲,线索链表。

二叉树遍历从根结点出发,按照某种次序依次访问二叉树中的节点,使得每个节点被访问一次,而且仅被访问一次。

遍历次序前提是限制从左到右:前序遍历(根左右)、中序遍历(左根右)、后序遍历(左右根)、层序遍历。

前序遍历(根左右)ABDGHCEIF

 

中序遍历(左根右)GDHBAEICF

 

 

后序遍历(左右根)GHDBIEFCA

 

层序遍历 ABCDEFGHI

 

 

二叉树遍历(递归算法):

面试题目:推导遍历结果。《大话数据结构P212》

二叉树建立:

 

前序:AB#D##C##

中序:#B#D#A#C#

后序:###DB##CA

8、线索二叉树指向前驱或者后继得指针称为线索,加上线索的二叉树链表称为线性链表,相应的二叉树就称为线索二叉树。(n个结点的二叉链表一共2n个指针域,一共n-1条分支数一共2n-(n-1)=n+1个空指针域。)

9、树、森林、二叉树的相互转化

将树转换成二叉树的步骤是:
1)加线。就是在所有兄弟结点之间加一条连线;
2)抹线。就是对树中的每个结点,只保留他与第一个孩子结点之间的连线,删除它与其它孩子结点之间的连线;
3)旋转。以树的根结点为轴心,将整棵树顺时针旋转一定角度,使之结构层次分明

注意事项:第一个孩子是二叉树结点的左孩子,兄弟转换过来的孩子是右孩子!!!

比如FG是右孩子,J是右孩子,而H、I是左孩子

森林转换为二叉树:森林是由若干棵树组成,可以将森林中的每棵树的根结点看作是兄弟,由于每棵树都可以转换为二叉树,所以森林也可以转换为二叉树。将森林转换为二叉树的步骤是:

1)先把每棵树转换为二叉树;

2)第一棵二叉树不动,从第二棵二叉树开始,依次把后一棵二叉树的根结点作为前一棵二叉树的根结点的右孩子结点,用线连接起来。当所有的二叉树连接起来后得到的二叉树就是由森林转换得到的二叉树。


二叉树转换为树:二叉树转换为树是树转换为二叉树的逆过程,其步骤是:
1)若某结点的左孩子结点存在,将左孩子结点的右孩子结点、右孩子结点的右孩子结点……都作为该结点的孩子结点,将该结点与这些右孩子结点用线连接起来;
2)删除原二叉树中所有结点与其右孩子结点的连线;(3)整理(1)和(2)两步得到的树,使之结构层次分明。

二叉树转换为森林:二叉树转换为森林比较简单,其步骤如下:
1)先把每个结点与右孩子结点的连线删除,得到分离的二叉树;
2)把分离后的每棵二叉树转换为树;(3)整理第(2)步得到的树,使之规范,这样得到森林。

根据树与二叉树的转换关系以及二叉树的遍历定义可以推知,树的先序遍历与其转换的相应的二叉树的先序遍历的结果序列相同;树的后序遍历与其转换的二叉树的中序遍历的结果序列相同;树的层序遍历与其转换的二叉树的后序遍历的结果序列相同。由森林与二叉树的转换关系以及森林与二叉树的遍历定义可知,森林的先序遍历和中序遍历与所转换得到的二叉树的先序遍历和中序遍历的结果序列相同。

10、哈夫曼树我们称判定过程最优的二叉树为哈夫曼树,又称最优二叉树。

路径: 树中一个结点到另一个结点之间的分支构成这两个结点之间的路径。

路径长度:路径上的分枝数目称作路径长度。

树的路径长度:从树根到每一个结点的路径长度之和。
结点的带权路径长度:在一棵树中,如果其结点上附带有一个权值,通常把该结点的路径长度与该结点上的权值之积称为该结点的带权路径长度。

树的带权路径长度:如果树中每个叶子上都带有一个权值,则把树中所有叶子的带权路径长度之和称为树的带权路径长度。其中带权路径长度最小的二叉树就称为哈夫曼树或最优二叉树。

哈夫曼树的构造:

构造Huffman树的方法————Huffman算法

构造Huffman树步骤

1、根据给定的n个权值{w1, w2, ...wn},构造n棵只有根节点的二叉数,令起权值为wj

2、在森林中选取两棵根节点权值最凶的树做左右子树,构造一棵新的二叉树,置新二叉树根节点权值为其左右子跟节点权值之和。

3、在森林中删除这两棵树,同时将新得到的二叉数加入森林中。

4、重复上述两步,直到只含一棵树为止,这棵树既是哈夫曼树

构造哈夫曼树得到的编码成为哈夫曼编码。常用于压缩。


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值