- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据库是课件的第六章
第六章 树和二叉树;6.1 树的类型定义;1. 熟练掌握二叉树的结构特性,了解相应的证明方法。
2. 熟悉二叉树的各种存储结构的特点及适用范围。
3. 熟练掌握各种遍历策略的递归和非递归算法。
4. 熟练掌握二叉树的线索化过程以及在中序线索化树上找给定结点的前驱和后继的方法。
5. 熟悉树的各种存储结构及其特点,掌握树和森林与二叉树的转换方法。
6. 了解最优二叉树的特性,掌握建立最优二叉树和哈夫曼编码的方法。;树(tree)是n(n=0)个结点的有限集T,其中:有且仅有一个特定的结点,称为树的根(root)。
当n1时,其余结点可分为m(m0)个互不相交的有限集T1,T2,……Tm,其中每一个集合本身又是一棵树,称为根的子树(subtree)
特点:
①非空树中至少有一个结点——根
②树中各子树是互不相交的集合;A;图形表示法
嵌套集合表示法
广义表表示法
凹入表示法
左孩子-右兄弟表示法;图形表示法:;树的其它表示方式;数据对象 D:;~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~; 基本操作:; Root(T) // 求树的根结点 ;InitTree(T) // 初始化置空树 ; ClearTree(T) // 将树清空 ;结点:;(从根到结点的)路径:;任何一棵非空树是一个二元组
Tree = (root,F)
其中:root 被称为根结点
F 被称为子树森林;(1) 有确定的根;
(2) 树根和子树根之间为有向关系。;一对多(1:n),有多个直接后继(如家谱树、目录树等等),但只有一个根结点,且子树之间互不相交。 ;讨论3:树的链式存储方案应该怎样制定?;树的运算 ;为何要重点研究每结点最多只有两个 “叉” 的树?
二叉树的结构最简单,规律性最强;
可以证明,所有树都能转为唯一对应的二叉树,不失一般性。;二叉树是n(n?0)个结点的有限集,它或为空树(n=0),或由一个根
结点和两棵分别称为左子树和右子树的互不相交的二叉树构成。
特点
① 每个结点至多有二棵子树(即不存在度大于2的结点)
②二叉树的子树有左、右之分,且其次序不能颠倒;A;ADT BinaryTree{
数据对象D:
数据关系R:
基本操作 P:
}ADT BinaryTree; 性质 1 :
在二叉树的第 i 层上至多有2i-1 个结点。(i≥1);性质2:深度为k的二叉树至多有2k-1个结点(k≥1)
证明:由性质1,可得深度为k 的二叉树最大结点数是:
;证明:
∵ 二叉树中全部结点数n=n0+n1+n2(叶子数+1度结点数+2度结点数)
又∵二叉树中全部结点数n=B+1 ( 总分支数+根结点 )
(除根结点外,每个结点必有一个直接前趋,即一个分支)
而 总分支数B= n1+2n2 (1度结点必有1个直接后继,2度结点必有2个)
三式联立可得: n0+n1+n2= n1+2n2 +1, 即n0=n2+1;2.深度为K的二叉树的结点总数,最多为 个。
A)2k-1 B) log2k C) 2k-1 D)2k;1、满二叉树
定义:一棵深度为k且有2k-1个结点的二叉树。
特点:每一层上的结点数都是最大结点数;2、完全二叉树
定义:深度为k,有n个结点的二叉树当且仅当其每一个结点都与深度为k的满二叉树中编号从1至n的结点一一对应时,称为完全二叉树。
特点:
(1)叶子结点只可能在层次最大的两层上出现。
(2)对任一结点,若其右分支下子孙的最大层次为L,则其左分支下子孙的最大层次必为L或L+1。;1;具有 n 个结点的完全二叉树的深度为 ? log2n? +1 。;一棵含有n个结点的二叉树,可能达到的最大深度和最小深度各是多少?
;性质5:如果对一棵有n个结点的完全二叉树的结点按层序编号,则对任一结点i(1≤i ≤ n),有:
(1) 如果i=1,则结点i是二叉树的根,无双亲;如果i1, 则其双亲是i/2。?
(2) 如果2in,则结点i无左孩子;如果2i ≤ n,则其左孩子是2i。
(3) 如果2i+1n,则结点i无右孩子;如果2i+1 ≤ n,则其右孩子是2i+1。;Q1:二叉树是不是树的特殊情况?
A1:不是!虽然二叉树也属于一种树结构,但它是另外单独定义的一种树,并非一般树的特例。它的子树有顺序规定,分为左子树和右子树。不能随意颠倒。
Q2:满二叉树和完全二叉树有什么区别?
A2:满二叉树是叶子一个也不少的二叉树,而完全二叉树虽然前n-1层是满的,但最底层却允许在右边缺少连续若干个结点。满二叉树是完全二叉树的一个特例。;a b c d e 0
文档评论(0)