软件开发技术--数据结构三.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
软件开发技术--数据结构三

如果给出一棵二叉树的先序遍历结果和中序遍历结果,或者给出后序遍历结果和中序遍历结果,就可画出该二叉树; 如果只给此二叉树出先序遍历结果和后序遍历结果,就无法画出该二叉树。 有两棵二叉树T1和T2,它们的先序和后序遍历结果完全相同。显然只凭先序和后序遍历结果无法确定到底是哪一棵二叉树。 从先序遍历序列中取出第一个结点,该结点必为根结点。然后在中序遍历中找出根结点,其前的序列为左子树,其后的序列为右子树。 对左右子树的先序遍历和中序遍历序列再重复第一步,直到得出所有叶结点为止。 则组成的二叉树为: 例: 先序为 ABCDEFGHI 中序为 BCAEDGHFI 分析:根据先序定义:A必为根结点。 根据中序定义:A前的结点为左子树. A后的结点为右子树。 作业: 1、对如下所示的二叉树写出其先序遍历、中序遍历和后序遍历的结果,并用程序验证结果的正确性。 2、已知二叉树的中序遍历为:GKMAQNBPD,后序遍历为: GKQABDPNM, 请构造出此二叉树并写出其先序遍历结果,并用程序验证结果的正确性。          * * * 直观上讲,满二叉树不缺少结点。 Complete binary tree: A binary tree in which every level, except possibly the deepest, is completely filled. At depth n, the height of the tree, all nodes must be as far left as possible. 除最底層外, 其他層都填滿, 而在最底層, 都優先填左邊的 nodes 只有最下面的两层结点度小于2,并且最下面一层的结点都集中在该层最左边的若干位置的二叉树. * 满二叉树第k层结点个数为2^(k-1), 因此,其结点总数为S=1+2^1+2^2+…+2^(k-1)=2^k-1 * * 如果二叉树是完全二叉树并保持这种状态,则基于数组的实现可以节省存储空间。 * (三)树 前面所学的数据结构都是线性关系结构,即每个数据元素都只有唯一的前驱元素和唯一的后继元素。但在客观世界中数据元素之间的关系不一定是线性关系,即不一定是唯一的前驱和唯一的后继,称为非线性关系结构。 树一种重要的非线性结构。 结点之间有分支、层次关系的结构。 递归定义: 有且仅有一个称为根的结点; 除根结点之外的结点可分为m(m=0)个互不相交的有限集T1,T2,...Tm,其中每一个集合本身又是一棵树,并且称为根的子树。 水果 芒果 苹果 梨 香蕉 红富士 黄元帅 秦冠 巴拿马 芝麻 水果分类示意图 结点:表示树中的数据元素; 根结点:是树中一个特定的结点,没有前趋结点; 叶子结点:表示没有后继的结点称为叶子(或终端结点); 分支结点:表示非叶子结点称为分支结点(或非终端结点); 结点的度:一个结点的子树数目就称为该结点的度;度为0的结点为终端结点或叶子。度不为0的结点称为非终端结点或分支结点。 树 的 度:一棵树上所有结点的度的最大值就是这棵树的度; 结点层次:确定根结点的层数为1,其它任何结点的层数等于它的父结点的层数加1; 树的高度:树中结点的最大层次又称为树的高度。 双亲结点:某结点的前驱结点被称为双亲结点; 兄弟:同一双亲的各子女间互称为兄弟。 森林:m(m0)棵互不相交的树的集合。 用树表示算术表示式(A+B)*5/(2*(C-D)) / * - * + 5 A B C D 2 用树表示家庭结构 老张 张一 张二 张小一 张小二 张小三 二叉树的结点子树要区分为左子树和右子树,即使在结点只有一棵子树的情况下,也要明确指出该子树是左子树还是右子树。 二叉树允许空,而一般的树至少有一个结点。 递归定义: 二叉树是n(n≥0)个结点的有限集合,且满足以下两条: 或者为空二叉树,即n=0; 或者由一个根结点和两棵互不相交的被称为根的左子树和右子树所组成,左子树和右子树分别又是一棵二叉树。 满二叉树:所有分支结点都存在左子树和右子树,且所有叶 结点都在同一层上,这样的二叉树称为满二叉树。深度为K的满二叉树有2K-1个结点。 完全二叉树:一棵深度为K的二叉树,若其叶结点都在第K层或第K-1层上,且最下层上的结点都集中在该层最左边的若干位置上,称为完全二叉树。 /div897/sqg/dads/HTML/completeBinaryTree.html 二叉排序树:左子树上所有结点的关键字均小于根结点的 关键字;右子树上所有结点的关键字均大于等于根结点的关键字。 若一棵

文档评论(0)

asd522513656 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档