重链剖分 学习记录

算法讲解161【挺难】树链剖分-上_哔哩哔哩_bilibili

重链剖分可以让树使用一个线性结构维护, 维护dfn序等信息

对于一个节点u的子树: 他的dfn序范围就是

对于每个重链上的点 都维护一个top信息 为这个重链的最顶端的节点

对于u, v路径上的节点, 比一下u, v节点top节点dfn序的大小, dfn序大的那个节点往上跳, 并更新/统计这个路径上的信息 一共最多跳log(n)次

核心代码:

cpp 复制代码
while(top[x] != top[y]) {
	if (dfn[top[x]] > dfn[top[y]]) {
		swap(x, y);
	}
	seg.rangeUpdate(dfn[top[y]], dfn[y], tag);
	y = fa[top[y]];
}
if (dfn[x] > dfn[y]) swap(x, y);
seg.rangeUpdate(dfn[x], dfn[y], tag);
相关推荐
智者知已应修善业29 分钟前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn31 分钟前
Java Set集合相关知识点
java·开发语言·算法
sakiko_1 小时前
UIKit学习笔记5-使用UITableView制作聊天页面
笔记·学习·swift·uikit
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星1 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
Alice-YUE2 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
云泽8082 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
科研前沿2 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨2 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
北山有鸟3 小时前
修改源码法和插件法
嵌入式硬件·学习