- 1、本文档共100页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
5.5 线 索 树;2.线索的方法存储结构 ;中序遍历:
H的前驱是D,
G的前驱是B;
X的前驱是A;思考:二叉链表空间效率这么低,能否利用这些空闲区存放有用的信息或线索?
——我们可以用它来存放当前结点的直接前驱和后继等线索,以加快查找速度。;线索二叉树的实现;图5.5.5 中序线索树;图5.5.6 二叉树;有关线索二叉树的几个术语:;例:【考研题】给定如图所示二叉树T,请画出与其对应的中序线索二叉树。 ;二叉线索树的结点结构定义 ;二叉线索树的遍历 ;前序二叉线索树的遍历 ;中序二叉线索树的遍历InOrderThread ;BinaryTreeNode *p=BT;
bool flag;
while ( !p ){
while (!p -Lflag) //查找一棵子树的最左子孙
p = p - LChild;
flag=true;
while (flag !p )
{
cout p -data ; //访问结点
p = p - RChild; //查找p的右子树的根或后继结点
if (!p - Rflag) //p结点存在右子树时,为强制退出作准备
flag = p - Rflag;
}};二叉树转化为二叉线索树;3。中序二叉树线索树中结点的插入 ;中序线索树中插入的新结点T作为S的左孩子 ;S结点的最右子孙→;图5.5.12 中序线索二叉树中T结点作为S的右孩子插入;5.6 一般树的表示和遍历 ;树和森林与二叉树的转换;方法:加线—抹线—旋转 ;二叉树怎样还原为树?;A;A;5.6.3 一般树的遍历概念 ;树若采用“先转换,后遍历”方式,结果是否一样?;5.6.4 一般树的运算 ;2。一般树二叉树形式存储下层次遍历 ;树的应用一(族谱);;树的应用二:利用树型结构的搜索算法模拟因特网域名的查询 ;5.7.1 分类二叉树 ;定义:;数据集合的关键字:{15,23,12,8,13,9,25,21,18} ;15;2 分类二叉树运算1)分类二叉树中数据元素的查找 ;2。将结点插入到分类二叉树中 ;while (p)
{
parent = p;
if (x.key p-data.key)
p = p-LChild;
else
if (x.key p-data.key)
p = p-RChild;
else
return false;//重复出现,即相等值结点出现
}
;// 找到插入点,为x申请一个空间填入其值,并将该结点连接至 parent;删除分类二叉树中的结点;;;;堆排序;1 堆树的定义 ;图5.7.5 最大树或最小树
;2 堆树的意义 ;堆排序--数据排序的一种经典方法 ;52;1.初始化一个非空的最大堆 ;1
;构造初始堆 ;构造N所指结点为根的堆算法思想:;for (int i = HeapSize/2; i = 1; i--)
//从最后一个结点的根开始,直到第一个结点
1)i= HeapSize/2=10/2=5,heap[5]=72
2)i- -;i=5 ; heap[4]=53
…..;最大堆调整(1);最大堆调整(2);初始化一个非空的最大堆算法 ;while (son = HeapSize)
{// 找左右孩子中较大结点
if (son HeapSize heap[son] heap[son +1])
son ++;
// son HeapSize时,存在右孩子,如左孩子小于右孩子,son指向右孩子
if (heap[0] = heap[son]) // 大孩子再与工作空间中结点值再比较
break; //工作空间中值大,找到heap[0]的目标位置
heap[son /2] = heap[son]; // 将大孩子上移至双亲位置
son * = 2;// son下移一层到上移的结点(大孩子)位置
}
heap[son /2] = heap[0]; //heap[0]存放到目标位置;4.堆排序 ;49;25;25*;21;16;利用分类二叉树查找及堆排序实现学生成绩管理 ;堆排序算法;Status MaxHeapDelete (EType a[], EType x)
{// 插入x到最大堆中
Heap = a;
if (HeapSize == 0) return ERROR; // 堆空
x = heap[1]; // 最大结点存放到x
heap[0] = heap[HeapSize--]; // 最后一个结点存放 到heap[0],调整堆中元素的个数
文档评论(0)