当前位置: 首页 > news >正文

LCT学习笔记

从例题开始:

P3690 【模板】动态树(LCT)

对于一棵静态的树,常见方法是树剖然后走链,但是在动态的情况下常见的重链或长链就会很慢,因为修改连边情况后就不满足性质了

引入一个新的方法:实链剖分,对于一个节点,任选一个儿子,连边为实边,其余为虚边,注意这里的实边是可以变化的

但是显然这样剖分的形式就不固定了,所以之前线段树维护的方法就不成立了,但是可以用 splay 解决

此时树变成了若干条实边和虚边,连接在一起的实边成为实链

对每条实链进行维护,使得 splay 的中序遍历为原树上深度从小到大排序的结果

对于虚边,作用是把这些 splay 连起来,方式如下:

  1. 找到该 splay 深度最小的节点,记为 k,若为根则不管

  2. 找到它的 fa,由它向当前 splay 的根连边

因为一个节点会有多个儿子,但是它只会存一个,就是认父不认子

区别于普通 splay,因为实链之间不能相互影响,操作时还需要判断是否为当前 splay 的根,如果是,返回-1,rotate 和 splay 函数区别不大

access:就是把点 x 到根路径上的点全部变成实边

首先将 x 转到当前 splay 的根,然后将 x 与 fa 之间的边变成实边,就是放到右儿子,然后处理 fa 所在子树,重复此操作直到整棵树的根

同时因为将 x 到根打包成一个 splay,所以 x 原来的实儿子变成虚儿子

makeroot:将 x 节点设为所在联通快的根

首先打通 x 到根的路径,此时 x 一定在这个子树的中序遍历的最后一位

如果我们将它设为根,那么它就是深度最小的点,但是他的 fa 作为深度第二大的点,理应在倒数第二位,翻转后会在第二位,这部分可以打懒标记实现

所以最后就是打通 x 到根的路径,然后把 x 转到根,给 x 打标记

同时将 x 转到根时,路径上的标记要全部下放

split:就是把 x 到 y 的路径变成实链,然后分成新的 splay,操作上就是先把 x 换到整棵树的根,然后打通 y 到根的路径,最后将 y splay 到子树的根

findroot:就是找到 x 所在点的实链的根,可以先将 x 转到根,此时因为根深度最小,暴力往左边找,注意下放标记,最后要转回去

link:连边,将 x 换到根,然后判断 y 和 x 是否在同一个联通快,不在就连一条虚边

cut:断边,先判断是否在一个联通快内,然后将路径独立出来,此时 y 若与 x 相连,则 y 在 x 的父亲且中序遍历上相邻,所以 x 不能有右子树

http://www.hskmm.com/?act=detail&tid=9496

相关文章:

  • Visual Studio 2026 Insiders 重磅发布:AI 深度集成、性能飞跃、全新设计
  • 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-29- 操作单选和多选按钮 - 下篇(详细教程) - 北京
  • 自定义注解实现服务分处理-策略模式
  • iOS26正式版全新风格!一文汇总实用新功能!
  • 远程控制应用的中的全球节点功能如何开启?插件类型、并发数量怎么选?
  • 借助Aspose.HTML控件,使用 Python 将 HTML 转换为 DOCX
  • openEuler 24.03 (LTS-SP2)安装mysql 8.0.41
  • 7.数据库归档异常检查与处理
  • Gitlab 关键字
  • 8.listener日志占用过大处理方法
  • 马建仓AI助手完成全链路升级:三十余项新能力重塑研发工作流
  • 线性回归与 Softmax 回归:深度学习基础模型解析 - 实践
  • 浏览器下载,一定要开启这个隐藏功能!
  • 开源项目进度管理系统 PJMan:让技术项目进度可视化、数据化的利器
  • 【光照】[漫反射]UnityURP兰伯特能量守恒吗?
  • Microsoft AI Genius 限时挑战赛:实战开启,等你应战!
  • DevSecOps革命:测试工具如何重塑企业数字化转型的质量防线
  • 3.sysaux tablesace 清理
  • 2.LOCK session
  • 2025 ~ 2026 游击 - gfoi
  • 【初赛】第二类斯特林数意义 - Slayer
  • 在AI技术快速实现功能的时代,挖掘新需求成为核心竞争力——某知名Android面试题库需求洞察
  • php本地搭建知识库实现rag遇到的一些问题解决方式
  • docker操作包括使用docker制作为接口
  • BuildingSystemPlugin使用指南
  • openEuler 24.03 (LTS-SP2)安装mysql5.7.42
  • Trae AI IDE与Gitee MCP深度整合:开启智能协作开发新时代
  • LangChain 入门:从 0 到 1 搞懂 LLM 应用开发框架​
  • [JOI Open 2023] 古代机器 2 / Ancient Machine 2 题解
  • Visual Studio 2022配置fftw第三方库