[蓝桥杯学习] 树链剖分

定义

将树分割成若干条链,以维护树上的信息,若无特殊需求,一般是重链剖分。

重链剖分

如何重链剖分

两个dfs

第一个dfs是预处理各个结点的基本信息,第二个dfs是利用信息进行剖分(dfs序)

操作步骤

第一次dfs
  1. 更新当前结点信息(子树个数、父结点信息、深度)
  2. 对子结点进行dfs
  3. 子结点dfs之后,把子结点的子树个数加到父结点,更新重儿子。
第二次dfs

因为dfs序连续的值是一条链,所以,我们需要让树在进行dfs时,优先对重儿子进行dfs,之后再对其它轻儿子进行dfs

重链剖分的应用

将剖分的重链放在线段数组或者树状数组上,然后在这个数据结构上进行维护。

对某条链上的节点进行更新

用数据结构对节点信息进行维护,进行区间查询,区间更新。

对某节点子树进行更新/查询

由dfs序可知,某节点的入序和出序之间的连续数就是该节点的子树。

查询两节点的最近公共祖先LCA

操作步骤:

  1. 当两节点不在同一条链上时,选择深度更浅的结点,跳到父链(链首的父结点)
  2. 当两节点在同一条链上时,深度更浅的点就是最近公共祖先LCA

查询、修改两节点之间路径的信息

主体还是寻找LCA,就是如果跳到父链(或是其它点),把x到它首结点(其它点)之间结点信息进行更新。

相关推荐
糕......8 分钟前
Java异常处理完全指南:从概念到自定义异常
java·开发语言·网络·学习
好奇龙猫11 分钟前
【人工智能学习-AI-MIT公开课-第5. 搜索:最优、分支限界、A**】
人工智能·学习
stars-he39 分钟前
FPGA学习笔记(7)以太网UDP数据报文发送电路设计(一)
笔记·网络协议·学习·fpga开发·udp
峥嵘life1 小时前
2026 Android EDLA 认证相关资源网址汇总(持续更新)
android·java·学习
熬夜造bug1 小时前
LeetCode非Hot100高频题(2)——常见LeetCode手撕
学习
Aliex_git1 小时前
Vue2 - Watch 侦听器源码理解
前端·javascript·vue.js·笔记·学习
程芯带你刷C语言简单算法题2 小时前
Day37~求组合数
c语言·开发语言·学习·算法·c
zhangfeng11332 小时前
大语言模型llm学习路线电子书 PDF、开源项目、数据集、视频课程、面试题、工具镜像汇总成一张「一键下载清单」
学习·语言模型·pdf
Fairy要carry2 小时前
VLLMs学习-LLMEngine(模型初始化)
学习
YJlio2 小时前
DiskView 学习笔记(13.3):用扇区视图看磁盘——热点盘块、碎片与健康排查
java·笔记·学习