刚开始学lct花了一晚上研究模板,调出来就感觉不怎么难打了。

对板子的浅显理解:

  lct维护树形联通块,通过splay维护实链,可以把需要的路径变换到一颗splay上维护。

  splay中的关系只依赖实边,一个点最多与两个实边相连,可以有不止两个儿子。也就是说,每个点的贡献由实边传递,必要时重分虚实来合并指定贡献。

   rotate 和 splay 只操作splay树。splay以深度为关键字排序。

   access 和 split 重新划分原树虚实,以重新划分splay的集合。

   makeroot 重新选原树的根,会改变原树父子关系。

   link 和 cut 对原树修改。

  每次splay节点父子关系变化/访问时,需要 download 或 updata 。

  lct的用法大概是对一条指定两端的路径进行求和、取min/max以及相应修改,并支持动态改边。把需要的路径split就可以直接访问根节点splay了。对于修改,为了避免从下往上的更新,先把节点splay到顶(splay中的根)再直接修改。

几点技巧:

  边权变点权:在两端点之间添一个点,其余点不参与贡献。样子和圆方树有点像。

  森林联通数:点数-变数。

几道题:

水管局长数据加强版:

  之前模拟赛好像做过类似的题。有一道题用并查集链并,还有一道是线段树分治,具体记不清了。

  这题的意思是寻找一条路径,使得路径上最大的边权最小化,其实是最小生成树。但有动态删边。LCT维护动态加边最小生成树比较容易,查询路径最大值就可以,但是有了删边,最大值难以维护。于是考虑离线,反过来加边就可以了。

GERALD07加强版:

  一开始有个鬼畜的想法:分块,小块中连$\sqrt N$条边,小块之间全连起来,每次把区间两端的小块切断,在连剩下的边。复杂度够呛,空间也开不下。。。

  这题关键在于联通块的计数。先考虑只有树形联通块:点数-变数就是了。如果是图的话,就意味着有些边在一个联通块内是多余的。考虑按序号逐个加边,当一条边的两点已经联通时,记录那条路上标号最小的边t,表示:如果t及之后的边和这条边一起出现,那么这条边就多余了。那么一段区间[l,r]的边的有效边就是t值小于l的边。用主席树维护。

魔法森林:

  相当于有两维限制的最小生成树,要求边上两元素最大值之和最小化。这类两维限制的题,可以考虑枚举一维,最优另一维。假设最终答案为(a,b),就是说,用A值不大于a的边和b值不大于b的边凑出的答案。我们按A从小到大枚举边,在把B那一维最优化,这样就是一维的最小生成树了。

在美妙的数学王国中畅游:

  首先动态改边不得不用LCT维护,那么考虑路径贡献总和的维护。对于点上的函数,如果是多项式的话我们就可以把多点的系数加和,最终带入就是贡献总和。那么就要把$sin(ax+b)$和$e^{ax+b}$拟成多项式了,泰勒展开。

  这题大概要展到20阶,少了WA0,多了TLE。一开始对一次函数的系数没有清空以为精度问题卡了半天。

情报传递:

  虽然并没有找到LCT的做法。

  每个情报员打上相应时间戳,查询操作即为求路径上小于$i-C_i$的点数,就是树上主席树。

  然后有一个naive的想法是用LCT的splay直接查pre,但是这里splay以深度为键值,十分cs。

LCT 总结的更多相关文章

  1. 一堆LCT板子

    搞了一上午LCT,真是累死了-- 以前总觉得LCT高大上不好学不好打,今天打了几遍感觉还可以嘛= =反正现在的水平应付不太难的LCT题也够用了,就这样好了,接下来专心搞网络流. 话说以前一直YY不出来 ...

  2. 动态树之LCT(link-cut tree)讲解

    动态树是一类要求维护森林的连通性的题的总称,这类问题要求维护某个点到根的某些数据,支持树的切分,合并,以及对子树的某些操作.其中解决这一问题的某些简化版(不包括对子树的操作)的基础数据结构就是LCT( ...

  3. 在此为LCT开一个永久的坑

    其实我连splay都还不怎么会. 今天先抄了黄学长的bzoj2049,以后一定要把它理解了. 写LCT怎么能不%数据结构大神yeweining呢?%%%chrysanthemums  %%%切掉大森林 ...

  4. 【BZOJ2157】旅游 LCT

    模板T,SB的DMoon..其实样例也是中国好样例...一开始不会复制,yangyang:找到“sample input”按住shift,按page down.... #include <ios ...

  5. 【BZOJ3669】[Noi2014]魔法森林 LCT

    终于不是裸的LCT了...然而一开始一眼看上去这是kruskal..不对,题目要求1->n的路径上的每个点的两个最大权值和最小,这样便可以用LCT来维护一个最小生成路(瞎编的...),先以a为关 ...

  6. 【BZOJ1180】: [CROATIAN2009]OTOCI & 2843: 极地旅行社 LCT

    竟然卡了我....忘记在push_down先下传父亲的信息了....还有splay里for():卡了我10min,但是双倍经验还是挺爽的,什么都不用改. 感觉做的全是模板题,太水啦,不能这么水了... ...

  7. 【BZOJ3282】Tree LCT

    1A爽,感觉又对指针重怀信心了呢= =,模板题,注意单点修改时splay就好,其实按吾本意是没写的也A了,不过应该加上能更好维护平衡性. ..还是得加上好= = #include <iostre ...

  8. BZOJ2888 资源运输(LCT启发式合并)

    这道题目太神啦! 我们考虑他的每一次合并操作,为了维护两棵树合并后树的重心,我们只好一个一个的把节点加进去.那么这样一来看上去似乎就是一次操作O(nlogn),但是我们拥有数据结构的合并利器--启发式 ...

  9. LCT裸题泛做

    ①洞穴勘测 bzoj2049 题意:由若干个操作,每次加入/删除两点间的一条边,询问某两点是否连通.保证任意时刻图都是一个森林.(两点之间至多只有一条路径) 这就是个link+cut+find roo ...

  10. 链剖&LCT总结

    在搞LCT之前,我们不妨再看看喜闻乐见的树链剖分. 树链剖分有一道喜闻乐见的例题:NOI2015 软件包管理器 如果你看懂题目了,你就会明白它是叫你维护一个树,这棵树是不会动的,要兹磁子树求和,子树修 ...

随机推荐

  1. 【阅读笔记:散列表】Javascript任何对象都是一个散列表(hash表)!

    什么是散列表? 散列表是Dictionary(字典)的一种散列表实现方式,字典传送门 一个很常见的应用是使用散列表来表示对象.Javascript语言内部就是使用散列表来表示每个对象.此时,对象的每个 ...

  2. go语言实现限流器

    本文:https://chai2010.cn/advanced-go-programming-book/ch5-web/ch5-06-ratelimit.html Ratelimit 服务流量限制 计 ...

  3. ABAP开发环境终于支持以驼峰命名法自动格式化ABAP变量名了

    Jerry进入SAP成都研究院前,一直是用C/C++开发,所以刚接触ABAP,对于她在某些语法环境下大小写敏感,某些环境下不敏感的特性很不适应.那时候Jerry深深地怀念之前在C/C++编程时遵循的驼 ...

  4. 将excel中的数据转为json格式

    ---恢复内容开始--- 用来总结工作中碰导一些错误,可以让自己在碰到相同错误的时候不至于重新走一遍.... 昨天导入数据的时候,碰到了一个问题是将一个大数组里面的每一个元素中的一些不要的去提出掉,本 ...

  5. jenkins安装和简单部署

    jenkins安装和简单部署 jenkins历史 jenkins是一款非常好用的团队CI(Continuous Integration)工具.它可以使你的构建,集成,发布,开发流程自动化.减轻各个环节 ...

  6. TLS 1.3 中Pre_shared_key和key_share对应的两种密钥交换模式

    1.TLS1.3的整个协议的文档规范 请参照 RFC 8846,协议规范中指出,TLS1.3提供三方面的安全属性,分别是身份认证.通信加密.完整性验证. 2.TLS1.3协议主要包括两个组成部分,分别 ...

  7. /sys 和 /dev 区别

    参考:What's the “/sys” directory for? Directory - /sys in linux 前言 各种Linux发行版下面似乎都有/sys目录,tree查看下面内容,会 ...

  8. k8s 证书之ca-csr.json,ca-config.json

    这是后面生成的所有证书的基础. 但如果是公司内使用,使用基于这些证书生成的ca, 在保证安全性的情况下,可以更方便的部署. ca-csr.json { "CN": "ku ...

  9. P1052 过河[DP]

    题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数 ...

  10. 团队作业Beta冲刺--第二天

    团队作业Beta冲刺 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 你们都是魔鬼吗 作业学习目标 (1)掌握软件黑盒测试技术:(2)学会编制软件 ...