这是一篇关于LCT的总结

加删边的好朋友——Link Cut Tree

Link-Cut Tree,LCT的全称

可以说是从树剖引出的问题

树剖可以解决静态的修改或查询树的链上信息;那如果图会不断改变,怎么办?

然后就有了LCT(真不知道发明它和它的那些拓展用法的人是怎么想出来的,创造力真强)

LCT要做的就是在不断的加边、删边等等改变图的操作中维护树的信息

不得不说,它很强大

本篇随笔只是记录一下自己对使用LCT的心得,如果你想从头开始学习LCT,可以去这里—— LCT总结+题单+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)

什么时候需要LCT?

一般情况下,如果题目中有加/删边的操作,那就套LCT进去,然后思考怎么用LCT完成其余的操作

不过真正的好题是完全看不出要用LCT的,所以更好的方法是先想到算法,然后用LCT维护算法中支持LCT维护的东西(数据结构其实本应这样用)

LCT的强大的操作们

动态维护树中的联通性

这是最简单的操作了,该link的link,该cut的cut,询问的时候,两个点都findroot一下,相同的话就是联通的,反之不联通

动态维护树的链上信息

这个也算是基本操作了,要找一条 \(u\) 到 \(v\) 的链,就先把 \(u\) makeroot到根,然后access一下 \(v\) (其实就是split),Splay维护好要维护的信息就行

动态维护图的生成树

这里开始就变成图了,不再单纯是树了

有时从题目中发现性质是要动态维护图的最大/小生成树(什么是动态?就是要维护正确性,那么在一个条件下,只有一些边在图中,其它的边不能够连)

其实就是四个字,化边为点

把原图的每一条边看成是一个点,那么 \(u\) 连到 \(v\) ,就变成了 \(u\) 连到了 \(s\) , \(s\) 再连到 \(v\) ,然后边权存在那条边化为的点上,其他的原图中真正的点对应的点没有点权,这样一条边如果加入了,那么它在Splay中就会有自己的贡献,如果要删掉,就断开它化为的点与这条边两端的点,自然就不会有它的答案计入

动态维护图的边双

这个东西算是比较玄学的了

加边的时候,发现这条边的两端如果已经联通,那么这条边加入后就一定会形成一个环,那么这个环里的所有点就处在一个边双里

怎么维护?

用另一个点表示这个边双(所有边双都新开一个点来表示),如果发现环,就把这个环里的所有点的父亲指向新点(一个dfs搞定),表示这些点已经归于一个边双了,然后这之中的所有点的操作都由新点代理进行,是不是很类似缩点,其实它就是缩点

很玄学,多看代码

动态维护树的子树信息

又回到树了,但是这也是最玄的

LCT是把一条链变成一个Splay,所以无论怎么搞,LCT里最终维护都是一条链上的信息,那如果题目要维护原树的子树信息,又要动态加边、删边怎么办?

那不随便,不管,还是LCT

注意LCT的构造,原树中一个节点的儿子(除实儿子)在LCT中一定是这个节点的虚儿子,那么如果要知道这个节点的原树信息,就是原树中的实儿子信息加虚儿子信息,实儿子信息LCT本身可以维护;那就只要知道虚儿子信息怎么维护。

这个还是简单的,一个数组搞定。LCT虽然一个节点只认一个儿子,但它的所有儿子都是认它的。所以对于儿子,把自己的信息加到父亲上去就搞定了

可以看看链接的博客,这一段讲得比较清楚

这个维护子树信息真的搞不透,有时候维护的东西从哪里取出来都不知道,我还是太菜了

一些套路

LCT能有什么套路

但还是有几个的

  • 能用并查集维护连通性的时候尽量用并查集,因为findroot太慢(只有加边的时候可以用并查集)
  • 对于一些题目,要维护生成树,但是要删边。而LCT维护生成树做不到把非树边代替树边。那么就离线倒过来做,从后往前,时光倒流(形容的很好),就变成只有加边了

好想我就只知道这么多了,我还是太菜了

一些练习题

为了暂时性的用好LCT,于是做了少许题目

大概是从简到难吧(不好排序),一类操作大部分在一起

接下来的题目就有一定难度了

正好30道,还有一些没做

因为省选来了,所以暂时放下(省选很虚啊,我还是太菜了

从未结束

从此,LCT的学习告一段落

倒计时,大后天

【总结】Link-Cut Tree的更多相关文章

  1. link cut tree 入门

    鉴于最近写bzoj还有51nod都出现写不动的现象,决定学习一波厉害的算法/数据结构. link cut tree:研究popoqqq那个神ppt. bzoj1036:维护access操作就可以了. ...

  2. Codeforces Round #339 (Div. 2) A. Link/Cut Tree 水题

    A. Link/Cut Tree 题目连接: http://www.codeforces.com/contest/614/problem/A Description Programmer Rostis ...

  3. Link/cut Tree

    Link/cut Tree 一棵link/cut tree是一种用以表示一个森林,一个有根树集合的数据结构.它提供以下操作: 向森林中加入一棵只有一个点的树. 将一个点及其子树从其所在的树上断开. 将 ...

  4. 洛谷P3690 Link Cut Tree (模板)

    Link Cut Tree 刚开始写了个指针版..调了一天然后放弃了.. 最后还是学了黄学长的板子!! #include <bits/stdc++.h> #define INF 0x3f3 ...

  5. LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)

    为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...

  6. bzoj2049 [Sdoi2008]Cave 洞穴勘测 link cut tree入门

    link cut tree入门题 首先说明本人只会写自底向上的数组版(都说了不写指针.不写自顶向下QAQ……) 突然发现link cut tree不难写... 说一下各个函数作用: bool isro ...

  7. P3690 【模板】Link Cut Tree (动态树)

    P3690 [模板]Link Cut Tree (动态树) 认父不认子的lct 注意:不 要 把 $fa[x]$和$nrt(x)$ 混 在 一 起 ! #include<cstdio> v ...

  8. Link Cut Tree学习笔记

    从这里开始 动态树问题和Link Cut Tree 一些定义 access操作 换根操作 link和cut操作 时间复杂度证明 Link Cut Tree维护链上信息 Link Cut Tree维护子 ...

  9. [CodeForces - 614A] A - Link/Cut Tree

    A - Link/Cut Tree Programmer Rostislav got seriously interested in the Link/Cut Tree data structure, ...

  10. Link Cut Tree 总结

    Link-Cut-Tree Tags:数据结构 ##更好阅读体验:https://www.zybuluo.com/xzyxzy/note/1027479 一.概述 \(LCT\),动态树的一种,又可以 ...

随机推荐

  1. svn 安装 配置及同步

    1.环境centos 2.安装svn #yum -y install subversion 3 查看版本 #svnserve --version 4 建立版本库目录 #mkdir /data/svnd ...

  2. 一次性搞定Session

    相信很多人遇到过同一个浏览器会出现Session覆盖问题.今天主要针对Session覆盖问题来看看Session是如何工作的.那么先看一张简单的图说明一下 上面的图大致的说明Session工作简单创建 ...

  3. github如何删除仓库中文件夹

    github项目中,经常大家更新.添加都非常熟悉,但是如果想要删掉一个文件夹,很多人就不知道怎么操作了. 网上查了一些方法,大部分都是删除仓库重新上传,这样肯定是不行的,首先不说任务量大,而且删除仓库 ...

  4. JavaScript正则表达式练习

    校验邮政编码(由六位组成). var reg = /^\d{6}$/; var str = "130400"; var b = str.match(reg); if (b === ...

  5. 【转】lvs、nginx、haproxy转发模式优缺点总结

    原文地址: https://yq.aliyun.com/ziliao/78374 一.LVS转发模式 LVS是章文嵩博士写的一个工作于四层的高可能性软件.不像后两者支持七层转发,不过也正因为其简单,所 ...

  6. SQL Server临时表漫谈

    SQL Server是微软的关系型数据库,对于刚入门的我是一个非常友好的开发工具.可视化界面的安装与操作,非常适合刚入门的我. 其实大家要找这方面的资料,在网上一搜一大堆,这里我就不赘述那些了,基本都 ...

  7. ICPC 沈阳 Problem C

    题意 求n的全排列中将前k个数排序后最长公共子序列>=n-1的个数 思考 我们先把最后可能产生的结果找出来,再找有多少种排列能构成这些结果 设排列为s S like 1,2,3,...,n , ...

  8. Fedora 28 UEFI模式安装过程记录

    这次的折腾是个意外.不过还是要记录一下. 多次做启动盘,把U盘做坏了.将U盘用量产工具修复以后就能做启动盘了.从官网下了Fedora 28的镜像(与CentOS同属RedHat系,尽量与鸟哥一致),用 ...

  9. centos上搭建git服务--4

    Git是目前世界上最先进的分布式版本控制系统(没有之一).使用Svn的请参考<版本控制-svn服务器搭建和常用命令(centos 6.3)>,下面介绍Git的常用命令 常用命令 简单版 升 ...

  10. 作业 20181120-3 Beta发布

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2408 小组介绍 组长:付佳 组员:张俊余 李文涛 孙赛佳 田良 于洋 段 ...