Splay Tree学习过程

2024-05-15 08:58
文章标签 学习 过程 tree splay

本文主要是介绍Splay Tree学习过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我把学习经历贴上来(包括看过那些论文,参考过哪些 博客)

http://en.wikipedia.org/wiki/Splay_tree

http://www.link.cs.cmu.edu/splay/  demo

http://www.artofproblemsolving.com/blog/54268 zkw大神

https://www.youtube.com/watch?v=nKZWL9hbcI4 动画演示

伸展树是什么,有什么用,如何实现?

(1)伸展树是什么?

伸展树是一种自适应的平衡二叉树,主要支持的操作是动态维护一个有序表, 从而支持字典, 前驱, 后继, 中序遍历, 优先队列等等多种操作(摘自http://www.artofproblemsolving.com/blog/54268)他支持二叉树的所有操作,并且摊还之后时间复杂度都为对数。但是并不保证某次操作都在对数时间内。

(2)伸展树有什么用?

白书里介绍了可分裂合并序列的一个典型应用时文本编辑器。因为文本需要在任意位置插入和删除字符,但是数组不能实现快速插入,链表不能快速定位。所以数组和链表这时都无用武之地。虽然两者结合起来,形成链式数组在实际运用中比较普遍。但是伸展树也不失为一个选择。(2014/8/11)

(3)如何实现?

首先我们要向伸展树的每个节点要维护哪些信息。要维护哪些信息,我们从他的基本操作入手。记得04年国家集训队论文杨思雨一文《伸展树的基本操作与应用》中给出9中基本操作,我们分析这九种操作然后确立维护哪些信息。

首先记住splay tree也是一种二叉查找树,所以维护的关键字是有序的。

操作1: 查找关键字X

       这根普通的二叉查找树没什么区别,我们只要从根节点出发,如果当前节点比要查找的关键字大,则查找右子树,如果比当前节点小,则查找左子树。如果等于那么返回当前节点。

操作2:求最大值

       因为是二叉查找树,所以最右边的叶子节点就是最大值。

操作3:求最小值

       因为是二叉查找树,所以最左边的叶子节点就是最小值。

操作4:求前驱

        这里我们如果对每个保存其父节点的,那么这操作就会简单许多。

操作5:求后继

        同理。

这里求前驱和后继要注意一下:

操作6:在介绍插入,删除操作之前,由于要维护树的平衡,所以我们还是先将旋转操作。

其实,旋转操作很好理解的,总共有六种,但是是对称的,所以知道三种,其他三种也就知道了。

1:如果要旋转的节点x的父节点是根节点,那么只要将父节点绕着x节点顺时针旋转一次就好

2:

操作6:插入操作X

      首先按照正常的二叉查找树的操作插入X,然后







这篇关于Splay Tree学习过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/991383

相关文章

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

SpringBoot集成SOL链的详细过程

《SpringBoot集成SOL链的详细过程》Solanaj是一个用于与Solana区块链交互的Java库,它为Java开发者提供了一套功能丰富的API,使得在Java环境中可以轻松构建与Solana... 目录一、什么是solanaj?二、Pom依赖三、主要类3.1 RpcClient3.2 Public

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

SpringBoot整合kaptcha验证码过程(复制粘贴即可用)

《SpringBoot整合kaptcha验证码过程(复制粘贴即可用)》本文介绍了如何在SpringBoot项目中整合Kaptcha验证码实现,通过配置和编写相应的Controller、工具类以及前端页... 目录SpringBoot整合kaptcha验证码程序目录参考有两种方式在springboot中使用k

SpringBoot整合InfluxDB的详细过程

《SpringBoot整合InfluxDB的详细过程》InfluxDB是一个开源的时间序列数据库,由Go语言编写,适用于存储和查询按时间顺序产生的数据,它具有高效的数据存储和查询机制,支持高并发写入和... 目录一、简单介绍InfluxDB是什么?1、主要特点2、应用场景二、使用步骤1、集成原生的Influ

SpringBoot实现websocket服务端及客户端的详细过程

《SpringBoot实现websocket服务端及客户端的详细过程》文章介绍了WebSocket通信过程、服务端和客户端的实现,以及可能遇到的问题及解决方案,感兴趣的朋友一起看看吧... 目录一、WebSocket通信过程二、服务端实现1.pom文件添加依赖2.启用Springboot对WebSocket

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp