热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

二叉搜索树之前驱后继

什么是二叉搜索树想必对二叉树都有了解,那么什么是二叉搜索树呢?首先给出每个节点的属性:1)keykey关键字2)pp父亲节点3)leftleft左孩子4)rightright

什么是二叉搜索树

想必对二叉树都有了解,那么什么是二叉搜索树呢? 
首先给出每个节点的属性: 
1)keykey 关键字 
2)pp 父亲节点 
3)leftleft 左孩子 
4)rightright 右孩子 
其定义如下: 
对于任何的节点xx,其左子树的关键字最大不超过x.keyx.key,其右子树的关键字最小不小于x.keyx.key 
下面的所有性质都是围绕该定义展开的。 
方法: 
1)遍历搜索二叉树:同遍历普通二叉树一般,前中后序,随你怎么来。时间复杂度为O(n)O(n)nn为节点数 
2)搜索二叉树:由于二叉树的定义规则,所以搜索的时候如同二分法,时间复杂度为O(h)O(h)hh为树的高度 
3)搜索树的最大最小关键字:同搜索二叉树类似,依据定义的规则,时间复杂度为O(h)O(h) 
4)插入删除的时间复杂度同样也为O(h)O(h)。插入比较简单,同搜索二叉树,直到出现节点为空,则该节点的位置即为插入位置;删除稍微复杂一些,需要考虑三种情况,不再细说,因为这些不是我想介绍的重点。我重点希望讲的是前驱和后继。

后继和前驱

什么是后继和前驱,如果对数的节点的关键字排序: 
key1<=key2<=......<=keyn3<=keyn2<=keyn1<=keynkey1<=key2<=......<=keyn−3<=keyn−2<=keyn−1<=keyn,那么keyn3keyn−3keyn1keyn−1就是keyn2keyn−2的前驱和后继 
后继 
寻找节点的后继被分为两种情况,分别是1)该节点的右子树非空;2)改节点的右子树为空。下面分别解释这两种情况 
1)右子树RR非空。这种情况下的寻找后继相对简单。对搜索二叉树的定义的了解可知,如果通过钟旭遍历二叉树,那么输出的关键字正好是从小到大排序。即遍历该节点之后应该要遍历该节点的右子树,而右子树非空,说明该节点的后继必定在该右子树中,且是右子树的关键字最小的节点,关键字最小的节点可以通过方法3)计算得到。 
2)右子树RR为空。该问题也就是访问完该节点aa,接下来该访问哪一个节点了呢?首先可以肯定的是,接下来要访问的节点是一个根节点。为什么呢?因为我们必须承认,除了根节点以外,任何节点都是某个节点的子树中的一部分。而对于右子树为空的情况,当访问完该节点aa后,以该节点作为根节点的树ZZ访问结束了。接下来可以分两种情况分析,该树ZZ为上一级节点的左子树,显而易见,访问完左子树ZZ就该访问该子树的根节点ee了。那么该根节点就是该节点aa的后继。若该子树为上一级节点的右子树ZZ,那么说明是访问完该根节点ee后再访问右子树的。所以其后继应该还在更上层的节点,直到遇到该节点所在的子树是某个节点qq的左子树的一部分为止。节点qq就是该节点的后继。 
前驱 
前驱和后继对称,不在赘述。 
1)如果节点的左子树非空,那么该节点的前驱就是左子树的最右边的节点(最大节点) 
2)如果节点的左子树为空,那么就以该节点不断回到其双亲节点,知道找到某个节点为其双亲节点的右节点 
则该双亲节点即为后继


推荐阅读
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细介绍了如何在BackTrack 5中配置和启动SSH服务,确保其正常运行,并通过Windows系统成功连接。涵盖了必要的密钥生成步骤及常见问题解决方法。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文探讨了如何在 React 和 TypeScript 中使用高阶组件(HOC)来消耗上下文,并详细解释了相关类型定义和实现细节。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • Yii 实现阿里云短信发送 ... [详细]
  • 本文探讨如何设计一个安全的加密和验证算法,确保生成的密码具有高随机性和低重复率,并提供相应的验证机制。 ... [详细]
  • 本文探讨了如何在发布 XenApp 应用时,通过命令行参数实现启动时的参数传递。特别介绍了静态和动态参数传递的方法,并详细解释了 ICA 文件中两种参数传递方式的区别及安全检查机制。 ... [详细]
  • 本文介绍如何通过注册表编辑器自定义和优化Windows文件右键菜单,包括删除不需要的菜单项、添加绿色版或非安装版软件以及将特定应用程序(如Sublime Text)添加到右键菜单中。 ... [详细]
author-avatar
牛尾巴2010
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有