【总结】静态点分治

这是一篇关于静态点分治的总结

点分治是什么?

就是一种统计答案的方式,用在树上
想要从头开始学点分治的话,可以点这里
点分治的标志:树上处理点对问题大部分用点分(当然还要复杂度允许)
对于一个树上点对问题,一个点只会有两种情况,一种是选,一种是不选
那么点分治就是按照这种思路去完成答案的统计,然后每次都找的是重心(size最大的子树的size最小的点),保证复杂度

一些可能有用的东西

点分治并不模板,而且还很思维。分治好后,统计答案还是需要思考的,而不是万能板子,所以没有捷径
这里只是一些去重的方法

  • 如果要统计的东西是一个整体的答案,而不针对于树上的每一个点,并且方便去重(感性理解),那么对于去重就直接在solve中枚举每一个子树去重就行了
  • 统计的如果是整体,但不方便去重,那么每个递归的solve,都是一遍维护,一遍算答案,维护的是当前枚举的子树之前的(或左边的)子树的贡献,然后对于当前子树算它与之前的子树的答案,这样就可以避免去重了,因为加的贡献一定不是同一个子树的
  • 如果答案需要针对每一个点,那么就一次递归中,就先把所有的子树答案先统计好,然后对于每一个子树,先把它的贡献从统计里减去,然后再算这个子树得到答案,然后再把这个子树的贡献加回去

一些题目

题目很少,做得不多

就只有4道了

从未结束

静态点分治弄完了 ????
接下来做题速度会慢下来,但每道题一定要满收获!!!!

原文地址:https://www.cnblogs.com/hongyj/p/8947542.html

时间: 2024-11-09 03:45:36

【总结】静态点分治的相关文章

bzoj1095: [ZJOI2007]Hide 捉迷藏 动态点分治学习

好迷啊...感觉动态点分治就是个玄学,蜜汁把树的深度缩到logn (静态)点分治大概是递归的时候分类讨论: 1.答案经过当前点,暴力(雾)算 2.答案不经过当前点,继续递归 由于原树可以长的奇形怪状(菊花啊..链啊..扫把啊..)这就导致各种方法都会被卡 于是通过每次找重心保证最大深度 动态怎么解决呢? 不妨考虑线段树是二分的固态版本(只可意会),那么我们把每次找到的重心固定下来长成一棵树就可以把点分治凝固(不可言传) 原来点分治该维护什么现在就维护什么... (事实上我并没有写过静态点分治..

学习笔记: cdq分治

今年的课程有很大一部分内容是cdq分治及其扩展(也就是二进制分组),拜读后觉得还是蛮有用的,这里小小地总结一下.(话说自己草稿箱里还有好多学习笔记的半成品呢,真是弱爆了.顺便感谢下fy与wxl向我介绍了那么好的东西) 推荐论文: 1 <从<Cash>谈一类分治算法的应用> 陈丹琦 2 <浅谈数据结构题的几个非经典解法>  许昊然 Q: cdq分治和普通的分治有什么区别? A: 在我们平常使用的分治中,每一个子问题只解决它本身(可以说是封闭的).而在cdq分治中,对于划分

【BZOJ1095】【ZJOI2007】捉迷藏 [动态点分治]

捉迷藏 Time Limit: 40 Sec  Memory Limit: 256 MB[Submit][Status][Discuss] Description 捉迷藏 Jiajia和Wind是一对恩爱的夫妻,并且他们有很多孩子.某天,Jiajia.Wind和孩子们决定在家里玩捉迷藏游戏. 他们的家很大且构造很奇特,由N个屋子和N-1条双向走廊组成,这N-1条走廊的分布使得任意两个屋子都互相可达. 游戏是这样进行的,孩子们负责躲藏,Jiajia负责找,而Wind负责操纵这N个屋子的灯. 在起初

初学CDQ分治-NEU1702

关于CDQ分治,首先需要明白分治的复杂度. T(n) = 2T(n/2)+O(kn), T(n) = O(knlogn) T(n) = 2T(n/2)+O(knlogn), T(n) = O(knlog^2n) T(n) = 2T(n/2)+O(k), T(n) = O(kn) 那么我们要处理[l, r]内的询问,我们可以分别处理[l, m]和[m+1, r]的询问,然后以较小的复杂度计算出[l, m]对[m+1, r]的贡献. 最简单的cdq就是三维偏序问题. 两点(x1, y1, z1)和(

数据持久化、单例、重载【添加对不可访问的成员的操作】、魔术方法、类常量、static关键字对self的补充【静态延迟绑定实现$this的效果】、参数类型约束【参数前加类名】、遍历【iterator接口】、快速排序

1.数据持久化过程[传输(例如表单提交或php交互mysql)和保存过程] 使用的是字符串形式的流数据. 数据流就是为了传输[按照序列的形式进行传输] [http://baike.baidu.com/link?url=0MtUQMhFzc_EwJc09rXZV8KlfOL4jis6XNbRfmGA3rQhDcGwOp8togLVQjXBV34M] 所以将其他类型数据转化为字符串的过程也是序列化的过程 [这个概念和图片.视频的流媒体的区别?] [注意点] 另外mysql中sql语句中的某些关键词为

CQH分治与整体二分

CDH分治,核心思想就是对操作进行二分.感觉和我以前对操作分块的思想很像啊,fhb分块 ……(⊙o⊙)… 日常懒得写模板的题解,转载一篇(本家) -----------------------------------------------------------分割线---------------------------------------------------------------------- 在线/离线:首要考虑 在线算法: 可以以序列化的方式一个一个的处理输入,不必事先知道所有

UVALive - 3938 分治,线段树,求动态最大连续和

UVALive - 3938 题意: 给出一个长度为n的整数序列D,你的任务是对m个询问作出回答.对于询问(a,b),需要找到两个下标x和y,使得a≤x≤y≤b,并且Dx+Dx+1+...+Dy尽量大.如果有多组满足条件的x和y,x应该尽量小.如果还有多解,y应该尽量小. tags: 分治思想,线段树       大白书201 区别于静态最大连续和,只能用分治算法: 最优解要么完全在左半序列,要么完全在右半序列,要么跨越中点. 我们构造一棵线段树,维护 3 个值:最大连续和 max_sub ,最

HAOI2017 八纵八横——线段树分治+线性基

题目大意 给定一个图,每次加一些边,或者删掉一些后来加上去的边,定义一个环的价值为环上所有的边的异或和,重复走的边重复算.每次询问这个时刻图中的所有经过1号点的环的最大价值. 思路 首先考虑对于一个静态的图如何求解图中所有经过1号点的环的最大价值,发现这个经过1号点就是唬人的,图中任意一个环都可以经过1号点再走回来. 于是题目变成了求解图中环的最大价值,可以将图中所有的简单环给拎出来放到线性基里面求最大价值,不难发现这是对的. 然后题目转化为了如何求图中所有的简单环,一般我们可以直接对图dfs找

CDQ分治总结

目录 例题 园丁的烦恼 树状数组1 陌上花开(三维偏序) 摩基亚 同步:https://buringstraw.win/index.php/archives/50/ 经过了一周的划水,我终于搞懂了cdq分治. 总的来说,cdq分治处理偏序问题就是 先把左边和右边当成一个完整的问题处理 然后把左边对右边的影响合并到右边 例题 园丁的烦恼 传送门 求静态区域内的点数,二维偏序模板题. #include<cstdio> #include<algorithm> const int MAXN