树链剖分/轻重链剖分

news/2025/10/24 0:04:47/文章来源:https://www.cnblogs.com/xihegudi/p/19161886

基础封装(配合线段树等数据结构使用)

本封装将线段树处理的部分分离,方便修改。支持模板题P3384 【模板】重链剖分/树链剖分的四个查询(链上查询/修改、子树查询/修改),建树时间复杂度 O(Nlog⁡N)\mathcal O(N\log N) ,单次查询时间复杂度 O(log2⁡N)\mathcal O(\log ^2 N) 。

struct HLD {int n, idx;vector<vector<int>> ver;vector<int> siz, dep;vector<int> top, son, parent;vector<int> in, id, val;Segt segt;HLD(int n) {this->n = n;ver.resize(n + 1);siz.resize(n + 1);dep.resize(n + 1);top.resize(n + 1);son.resize(n + 1);parent.resize(n + 1);idx = 0;id.resize(n + 1);val.resize(n + 1);}void add(int x, int y) { // 建立双向边ver[x].push_back(y);ver[y].push_back(x);}void dfs1(int x) {siz[x] = 1;dep[x] = dep[parent[x]] + 1;for (auto y : ver[x]) {if (y == parent[x]) continue;parent[y] = x;dfs1(y);siz[x] += siz[y];if (siz[y] > siz[son[x]]) {son[x] = y;}}}void dfs2(int x, int up) {id[x] = ++idx;val[idx] = in[x]; // 建立编号top[x] = up;if (son[x]) dfs2(son[x], up);for (auto y : ver[x]) {if (y == parent[x] || y == son[x]) continue;dfs2(y, y);}}void work(int root, auto in) { // 在此初始化this->in = in;dfs1(root);dfs2(root, root);segt.init(val); // 建立线段树}void modify(int l, int r, int val) { // 链上修改while (top[l] != top[r]) {if (dep[top[l]] < dep[top[r]]) {swap(l, r);}segt.modify(id[top[l]], id[l], val);l = parent[top[l]];}if (dep[l] > dep[r]) {swap(l, r);}segt.modify(id[l], id[r], val);}void modify(int root, int val) { // 子树修改segt.modify(id[root], id[root] + siz[root] - 1, val);}int ask(int l, int r) { // 链上查询int ans = 0;while (top[l] != top[r]) {if (dep[top[l]] < dep[top[r]]) {swap(l, r);}ans += segt.ask(id[top[l]], id[l]);l = parent[top[l]];}if (dep[l] > dep[r]) {swap(l, r);}return ans + segt.ask(id[l], id[r]);}int ask(int root) { // 子树查询return segt.ask(id[root], id[root] + siz[root] - 1);}
};

模板题

P3384 【模板】重链剖分/树链剖分

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/944779.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#编程时winform程序登陆记住密码和自动登录功能,关于App.config的问题及解决方案

一、问题起因及来由 最近由于自己工作需要,把丢了十几年没有用过的编程软件知识捡起来,虽然十几年了,但还是忘不了,还是喜欢自己敲代码,遇到问题后,体验解决问题的后的快感。 同时也喜欢看着自己敲出的一系列整齐…

2025.10.23总结

软考还有两周左右,得抓紧复习了,目前仅仅在网上找题库刷了一点电题,得快点看完知识点讲解后刷题,剩下一周就以刷题为主了。因为目前的时间不能以天算,加上上课的时间,写作业,写项目等待。用在复习上的时间,每天…

[C/C++] Linux 环境变量(C/C++ ver)

[C/C++] Linux 环境变量(C/C++ ver)$(".postTitle2").removeClass("postTitle2").addClass("singleposttitle");Grok 生成(2025年10月23日23:53:07)🌟 Linux 环境变量(C/C++ ver)…

诗词大会day1

诗词大会day1$(".postTitle2").removeClass("postTitle2").addClass("singleposttitle");成语血脉偾(fen四声)张:形容情绪极度激动、兴奋,导致血液流动加速,血管膨胀的感觉。 如椽…

Day2超链接标签

超链接的作用是跳转到其他网页<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,…

Ai元人文构想:你喜欢黑箱与偏见

你喜欢黑箱与偏见 在这个被算法支配的时代,我们都在参与一场心照不宣的共谋——你爱黑箱,我恋偏见。 这不是什么难以启齿的秘密,而是我们在这个过度刺激的世界里生存下来的智慧。黑箱多么美妙,它把复杂的因果、矛盾…

企业微信 使用api批量处理群消息

好的,我们来详细讲解如何为企业微信创建API接口,以便实现批量发送等高级功能。 创建企业微信API接入的核心是为你的企业创建一个“自建应用”,然后获取这个应用的访问凭证。整个过程可以分为以下几个步骤:第一步:…

first game (1)

初步搭完场景跟人物一些tips:F5 运行 F8 退出运行 Ctrl+A 创建新子节点 Ctri+S 保存耗时≈一小时 明天继续

10月23日日记

1.今天上体育课。 2.明天学习英语 3.为什么哈希表的查询可以做到O(1)?

软件工程学习日志2025.10.23

目标:完成 MapReduce 词频统计程序的远程执行链路,支持用 java -jar 直接运行 RemoteRunner,并解决参数传递与 HDFS/SSH 连接问题。 结果:RemoteRunner 已增强为“更健壮的远程执行器”,能自动探测 HDFS、在无参数…

66ye

`import torch import torch.nn as nn import torch.optim as optim from torch.utils.data import DataLoader from torchvision.datasets import CIFAR10 from torchvision.transforms import Compose, ToTensor, No…

Gin笔记一之项目建立与运行

本文首发于公众号:Hunter后端 原文链接:Gin笔记一之项目建立与运行本篇笔记开始介绍 Golang 的 web 框架 Gin 的相关内容。 本系列笔记预计通过四到五篇笔记内容介绍 Gin 框架的核心内容,然后通过一个简单的示例介绍…

【题解】P14254 分割(divide)

想了想,感觉这道题还是总结一下为好。 这个题需要涉及大量证明,也是很恶心人了。 引理一:当第 \(1\) 个点选择了深度为 \(i\),那后续所有节点的深度就只能为 \(i\)。 证明:因为选择的点的深度是不降得,所以不能选…

10.23日学习笔记

一、应用层在 TCP/IP 中的位置 最顶层,直接为用户的应用程序提供网络服务。 不关心底下几层如何传输,只关心“消息语义”与“交换规则”。 典型交互模型: 客户/服务器(C/S) P2P(对等) 混合(边缘 P2P + 索引服务…

埃氏筛及扩展质因数筛——埃拉托斯特尼筛法变种

质数筛这段代码用 “埃拉托斯特尼筛法” 找 2 到 N 之间的所有素数,逻辑很直接:先假设所有数都是素数(用vis数组标记,初始全为true); 排除 0 和 1(它们不是素数,标记为false); 从 2 开始,对每个没被排除的数…

Day2路径,相对与绝对

路径指的是查找文件时,从起点到终点经历的路程 路径也分为绝对路径与相对路径 相对路径是从当前文件出发查找目标额文件 绝对路径是从盘符出发找目标文件 Windows电脑是从盘符出发的,而Mac电脑则是从根目录出发 在…

第九届强网杯线上赛PWN_flag-market

第九届强网杯线上赛PWN_flag-market第九届强网杯线上赛PWN_flag-market 一、题目二、信息搜集 下载题目给的附件,查看文件ctf.xinetd之后,知道我们的可执行程序名为chall:这个文件在附件中的bin目录下。 通过file命…

ISFB银行木马家族演化史:从Gozi到LDR4的技术剖析

本文深入分析ISFB银行木马家族十年演化历程,详细解析其技术架构、功能模块和分支变种,包括加载器、键盘记录、Web注入、VNC远程控制等核心功能,揭示网络犯罪组织的运作模式和技术演进。第1章 — 从Gozi到ISFB:一个…

exgcd板子

void exgcd(int &x,int &y,int a,int b) {if(!b){x=1;y=0;return;}exgcd(x,y,b,a%b);int t=x;x=y;y=t-a/b*y; }