- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第五章 树与二叉树;3. 树的逻辑结构 ;3;4;5;6;7;8;二叉树的性质;定义1 满二叉树 (Full Binary Tree) 定义2 完全二叉树 (Complete Binary Tree) ─ 若设二叉树的深度为 k,则共有 k 层。除第 k 层外,其它各层 (1—k-1) 的结点数都达到最大个数,第k层从右向左连续缺若干结点,这就是完全二叉树。 ;性质3 对任何一棵二叉树,如果其叶结点有 n0 个, 度为 2 的非叶结点有 n2 个, 则有 n0=n2+1 若设度为 1 的结点有 n1 个,总结点数为n, 总边数为e,则根据二叉树的定义, n = n0+n1+n2 e = 2n2+n1 = n-1 因此,有 2n2+n1 = n0+n1+n2-1 n2 = n0-1 n0 = n2+1 ;性质4 具有 n (n≥0) 个结点的完全二叉树的深度为 ?log2(n+1)? 设完全二叉树的深度为k,则有 2k-1-1 n ≤ 2k-1 变形 2k-1 n+1≤2k 取对数 k-1 log2(n+1) ≤k 有 ?log2(n+1)? = k;性质5 如将一棵有n个结点的完全二叉树自顶向下,同一层自左向右连续给结点编号1, 2, …, n,则有以下关系: 若i = 1, 则 i 无双亲 若i 1, 则 i 的双亲为?i/2? 若2*i = n, 则 i 的左子女为 2*i, 若2*i+1 = n, 则 i 的右子女为2*i+1 若 i 为奇数, 且i != 1, 则其左兄弟为i-1, 若 若 i 为偶数, 且i != n, 则其右兄弟为i+1;二叉树的抽象数据类型; bool IsEmpty (); //判二叉树空否? BinTreeNodeT *Parent (BinTreeNodeT *t); //求结点 t 的双亲 BinTreeNodeT *LeftChild (BinTreeNodeT *t); //求结点 t 的左子女 BinTreeNodeT *RightChild (BinTreeNodeT *t); //求结点 t 的右子女 bool Insert (T item); //在树中插入新元素 bool Remove (T item); //在树中删除元素 bool Find (T item); //判断item是否在树中 bool getData (T item); //取得结点数据; BinTreeNodeT *getRoot (); //取根 void preOrder (void (*visit) (BinTreeNodeT *t)); //前序遍历, visit是访问函数 void inOrder (void (*visit) (BinTreeNodeT *t)); //中序遍历, visit是访问函数 void postOrder (void (*visit) (BinTreeNodeT *t)); //后序遍历, (*visit)是访问函数 void levelOrder (void (*visit)(BinTreeNodeT *t)); //层次序遍历, visit是访问函数 };;17;18;19;20;21;练习;一棵含有n个结点的k叉树,可能达到的最大深度为 ? ,最小深度为 ? 。;由n个结点所构成的二叉树有 ? 种形态。;25;26;二叉树的链表表示(二叉链表);28;二叉树的类定义;template class T class BinaryTree { //二叉树类定义 public: BinaryTree () : root (NULL) { } //构造函数 BinaryTree (T value) : RefValue(value), root(NULL) { } //构造函数 BinaryTree (BinaryTreeT s); //复制构造函数 ~BinaryTree () { destroy(root); } //析构函数 bool IsEmpty () { return root == N
您可能关注的文档
最近下载
- 《碳纤维片材加固混凝土结构技术规程》(2022年版).doc
- 小学生主题班会 遵守纪律 课件(共23张PPT).pptx VIP
- 职业生涯人物访谈报告(采访教师)汇编.pdf VIP
- 氯及其化合物同步练习 2024-2025学年高一上学期化学人教版(2019)必修第一册.docx VIP
- 2025年全国中小学生天文知识竞赛试题库(含答案).docx VIP
- 2026山东省公务员省考试题及答案.doc VIP
- 爆破工程技术人员取证培训初级D设计题真题参考答案.pdf VIP
- 融创集团空鼓、开裂常见问题分析.pdf VIP
- 突发事件紧急医学救援“十五五”规划(2025-2025年).docx VIP
- 厂房钢结构专项施工方案.docx VIP
有哪些信誉好的足球投注网站
文档评论(0)