《【7-2】二叉搜索树》-课件设计(公开).pptVIP

《【7-2】二叉搜索树》-课件设计(公开).ppt

  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文档。上传文档
查看更多
数据结构 中国地质大学信息工程学院 2013年秋 第七章 搜索结构 内容提要 搜索概述 静态搜索结构 动态搜索结构 二叉搜索树(BST) 平衡二叉树(AVL) 1.二叉搜索树 ( Binary Search Tree ) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 每个结点都有一个作为搜索依据的关键码(key),所有结点的关键码互不相同,都是唯一的 左子树(如果非空)上所有结点的关键码都小于根结点的关键码。 右子树(如果非空)上所有结点的关键码都大于根结点的关键码。 左子树和右子树也是二叉搜索树。 二叉搜索树示例 二叉搜索树的结点定义 template class E, class K struct BSTNode { //二叉树结点类 E data; //数据域 BSTNodeE, K *left, *right; //左子女和右子女 BSTNode() { left = NULL; right = NULL; } //构造函数 BSTNode (const E d, BSTNodeE, K *L = NULL, BSTNodeE, K *R = NULL) { data = d; left = L; right = R;} //构造函数 ~BSTNode() {} //析构函数 void setData (E d) { data = d; } //修改 E getData() { return data; } //提取 二叉搜索树的类定义 void makeEmpty() //置空 { makeEmpty (root); root = NULL; } void PrintTree() const { PrintTree (root); } //输出 E Min() { return Min(root)-data; } //求最小 E Max() { return Max(root)-data; } //求最大 bool Insert (const E e1) //插入新元素 { return Insert(e1, root);} bool Remove (const K x) { return Remove(x, root);} //删除含x的结点 private: BSTNodeE, K *root; //根指针 K RefValue; //输入停止标志 BSTNodeE, K * //递归:搜索 Search (const K x, BSTNodeE, K *ptr); void makeEmpty (BSTNodeE, K * ptr); //递归:置空 void PrintTree (BSTNodeE, K *ptr) const; //递归:打印 BSTNodeE, K * //递归:复制 Copy (const BSTNodeE, K *ptr); BSTNodeE, K* Min (BSTNodeE, K* ptr); //递归:求最小 BSTNodeE, K* Max (BSTNodeE, K* ptr); //递归:求最大 bool Insert (const E e1, BSTNodeE, K* ptr); //递归:插入 bool Remove (const K x, BSTNodeE, K* ptr); //递归:删除 }; 二叉搜索树的类定义用二叉链表作为它的存储表示,许多操作的实现与二叉树类似。 2. BST-搜索 【思想】假设需要查找关键值为 k的元素,先从根开始。如果根为空,那么搜索树不包含任何元素,查找失败,否则将 k与根的关键值相比较: 如果 k小于根节点的关键值,则只需在左子树中搜索即可; 如果 k大于根节点的关键值,则只需在右子树中搜索即可; 如果 k等于根节点的关键值,则查找成功,搜索终止! BST-搜索算法 templateclass E, class K BSTNodeE, K* BSTE, K:: Search (const K x, BSTNodeE, K *ptr) { //私

您可能关注的文档

文档评论(0)

沙卡娜 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档