- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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工工艺规程及连杆大头侧面加工工序夹具设计》-毕业论文设计(学术).doc
- 《触摸屏生产流程》-课件设计(公开).ppt
- 《(程善)拉普拉斯变换》-课件设计(公开).ppt
- 《(姜凤英)心身疾病的诊断与治疗》-课件设计(公开).ppt
- 《(免费)雷克萨斯顾客满意度培训(免费分享)》-课件设计(公开).ppt
- 《(全)183埃森哲《天津汽车工业集团公司发展战略摘要报告》-课件设计(公开).ppt
- 《(说课)乳品畜牧业》-课件设计(公开).ppt
- 《[]地铁车站暗挖施工技术交流(PBA工法)》-课件设计(公开).ppt
- 《[技巧][沟通][谈判][能力训练]专业谈判技巧培训修改》-课件设计(公开).ppt
- 《[史上最强生物课件]选修一果酒和果醋的制作》-课件设计(公开).ppt
- 《【2011酒店管理资料】汉庭酒店前台管理112096》-课件设计(公开).ppt
- 《【js】07JavaScript与面向对象编程》-课件设计(公开).ppt
- 《【ty龙虾面FGD报告】》-课件设计(公开).ppt
- 《【变态心理学经典】儿童心理障碍》-课件设计(公开).ppt
- 《【步步高】2012年高考语文大二轮专题复习热身训练半》-课件设计(公开).ppt
- 《【创新设计】2013-2014学年高中语文人教版选修《外国小》-课件设计(公开).ppt
- 《【创新设计】2013-2014学年高中语文粤教版选修《唐诗宋》-课件设计(公开).ppt
- 《【飞利浦公关活动方案】》-课件设计(公开).ppt
- 《【黄冈市蔡河中学陈小兵汇编】新人教版九年级化学上册62733763》-课件设计(公开).ppt
- 《【金属即热处理】7章单相固溶体合金及铸锭的凝固费》-课件设计(公开).ppt
最近下载
- ISO∕IEC 42001-2023人工智能管理体系之5:“5领导作用-5.1领导作用和承诺”解读、实施流程和风险描述(雷泽佳编制-2024).pdf VIP
- 中学生心理辅导案例.docx
- 药厂公用系统培训课件.ppt
- 以案说法-中南财经政法大学-中国大学MOOC慕课答案.pdf VIP
- 现行建筑工程施工工艺标准.doc VIP
- 人教版七年级下册语法专项练习题一(一般现在时,一般过去式,现在进行时).docx VIP
- 药品采购流程中的供应商评估标准.docx VIP
- erp软件培训ppt课件.pptx
- GB/T 4456-2008_包装用聚乙烯吹塑薄膜.pdf
- 高空作业平台施工安全标准化实施方案.docx VIP
原创力文档


文档评论(0)