$LCT$维护子树信息学习笔记
\(LCT\)维护子树信息学习笔记
昨天\(FDF\)好题分享投了 \([ZJOI2018]\)历史 这题。
然后我顺势学学这个姿势。
结果调了一年。。。于是写个笔记记录一下。
基本原理
比较显然地,虽然父子关系在不断变化,但是重链与重链之间的连接是不变的。换句话说,一个点的某个虚儿子也许并不是他在原树中的某个儿子,但是这个点总和上来的信息是这整棵子树的。
所以我们定义这个点总和的信息(记为\(siz\))为总和该子树的所有信息,
然后记\(fsz\)为虚儿子的总和信息,\(val\)为单点信息。
那么可以得到信息的统计式为:
\(siz[x]=siz[ls]+siz[rs]+fsz[x]+val[x]\)
若将\(x\)做\(Splay\)到根的话,则这个点的\(siz\)就是以这条重链链顶为根的子树的信息和。
(一定把原树和\(LCT\)分开啊
而如果我们要查以某个点为根的子树信息和的话,则先将其\(Splay\)到根,
那么所求即为:\(siz[rs]+fsz[x]+val[x]\)
很简单,就是自己重儿子的所有信息加上自己的虚子树信息以及自己
这里\(siz\)的用处自己脑补一下,很显然这个信息用\(siz\)整合出来也是对的。
这就是最基本的做法了。
虚实信息维护
这个很好办,考虑虚实边的修改只会在一些情况下出现。
\(Access:\)直接做加减法维护\(fsz\)就行了。
\(Link:\)因为每次连边是连一条虚边,所以我们直接维护,要注意的是作为儿子的点要被\(Splay\)上来总和信息。
\(Cut:\)没有特别的地方,和上面一样做即可。
带单点修改
如果带修改,那么就意味着我们需要更新这个被修改点到原树树根的信息。
到树根?\(Access!\)
直接大力\(Access\)一波,每次跳一条虚边就直接做一次单点修改就行了,注意切换虚实边。
特技?
如果要求魔改\(Access?\)
那得好好研究一下它到底长啥样啊。
首先,\(Access\)中前一条重链那棵\(Splay\)的根不一定是你的原树中的那个儿子,你得一直沿着左儿子找,找到深度最小的那个才是。
这个找的复杂度应该与\(Splay\)的复杂度相当,所以不影响其复杂度。
然后呢,你想要那个儿子的子树信息怎么办?再\(Splay\)上去?
不用了,虽然前一条重链那棵\(Splay\)的根不一定是你的原树中的那个儿子,但是它确确实实总和了那棵子树的信息,所以直接调用它的信息即可。
想用\(Access\)模拟某种染色过程?
不就是有些边不能连吗?信息还是直接加加减减来维护,连边特判就行了。
那为什么历史那题要写这么久?
我菜。
所以这个还是比较简单的,毕竟目前没写到太喵的做法。
那么就这样了。
随机推荐
- fedora18 [linux]Error: failure: repodata/repomd.xml from fedora: [Errno 256] No more mirrors to try.
在使用fedora17 系统的yum源的时候出现了如下错误: Error: failure: repodata/repomd.xml from fedora: [Errno 256] No more ...
- tab下图表展示宽高为0的问题
tab下,默认展示第一个tab(最新订阅),第二个tab是echarts,需要动态获取父级div的宽高并赋值到图表的DOM的宽高.在实际开发过程中,发现无论如何延迟处理,或者mounted,第二个ta ...
- seq使用
转载! 用于产生从某个数到另外一个数之间的所有整数例一:# seq 1 10结果是1 2 3 4 5 6 7 8 9 10例二:#!/bin/bashfor i in `seq 1 10`;doech ...
- 十六、简单配置jenkins执行本地的robotframework项目
A.前期准备: 1.登录jenkins 2.系统管理-插件管理-高级-上传插件(http://mirrors.jenkins-ci.org/plugins/robot/,中选择一个版本的插件下载至本地 ...
- 项目开源-基于ASP.NET Core和EF Core的快速开发框架
前言:作为一名95后的程序猿,已经写了一年多的代码了,为了提升自己的技术水平,所以决定尝试编写一个快速开发框架开源出来,一来提升自己的技术水平,二来助力.NET Core生态发展 写这个框架主要是为了 ...
- 多线程threading初识,线程等待
1.线程是程序里面最小的执行单元. 2.进程是资源的集合. 线程是包含在进程里面的,一个进程可以有多个线程,但只要要有一个线程. 一.多线程,就是N个线程一起干活: 1.传统方式,串行,循环5次需要1 ...
- Numpy和Pandas
NumPy是高性能科学计算和数据分析的基础包.数据结构为ndarray,一般有三种方式来创建.ndarray是N-Dimensions-Array(N维数组)的简称,ndarray要求元素数据类型一致 ...
- 关于staticmethod() 函数
说实话,我就不知这个是干什么的. 菜鸟教程写的无需实例化, 自己可以调用自己. 在同一个类面我使用到了 因为一个类了, 我可能会方法间互相调用. 类中间使用.不加这个,就会报错.无法识别这个 orig ...
- 山西汽车销量(hive)
1.创建数据库create database db_cart; 2.使用数据库use db_cart; 3.创建表create table t_cart(province STRING,month I ...
- 解决sql语句中参数为空(null)不会更新参数的问题
用的mybatis自动生成的 情景: 修改页面中,修改某个字段,修改前有数据,修改后为空. mybatis中一般用到 如:(这种直接忽略为空的字段,不能更新空字段参数) <update id=& ...