http://www.lydsy.com/JudgeOnline/problem.php?id=1036php
https://oi.men.ci/tree-chain-split-notes/、ide
https://oi.men.ci/tree-divide-notes/优化
https://www.luogu.org/blog/chengni5673/dian-fen-zhi.net
对于一棵树,统计长度为 x 的路径的路径数.blog
点分治: 找到一个点为根,统计答案,而后将它的子树分离,分别进行一样的操做,继续,直到只剩下一个点. 其中选择的根是有要求的,为了保证时间复杂度,咱们须要尽可能的让子树的大小相近,因此每一次咱们选择的根都最好是当前这棵树的重心.ci
Graph 1. 求各点到指定点集的最短距离的优化方法get
(a)it
(b)class
Graph 2. 二分彻底图建边的优化方法技巧
Graph 3. 建边的线段树优化
分层图就是有多维状态的有边长图,比起正常的最短路转移多了一种跨维度转移的状态转移. 通常都是舍去某边长度,最多舍多少次 (次数较少).
[JLOI2011] 飞行路线: Alice 和 Bob 如今要乘飞机旅行,他们选择了一家相对便宜的航空公司。该航空公司一共在 n 个城市设有业务,设这些城市分别标记为 0 到 n-1,一共有 m 种航线,每种航线链接两个城市,而且航线有必定的价格。Alice 和 Bob 如今要从一个城市沿着航线到达另外一个城市,途中能够进行起色。航空公司对他们此次旅行也推出优惠,他们能够免费在最多 k 种航线上搭乘飞机。那么 Alice 和 Bob 此次出行最少花费多少?
分层图能够很巧妙的解决这个问题. 想象你每次使用免费航线以前和以后分别存在于不一样的时空 (不一样的层) 里面,每使用一次免费航线,你就从这个时空进入了另外一个时空 (免费). 根据以上思想建图,一共建 k+1 层图,相邻的两层图中进行连边 (单向边,距离为 1). 而后跑 Dijkstra 便可.