Kruskal重构树
参考: 老师讲解 Fighting_Peter 的文章 其实Kruskal重构树并不难。 概览 首先,Kruskal重构树,顾名思义就是把整棵树重构。 并且其是基于Kruskal算法的。 它能解决很多问题,并且变种很多。 但我们先从基础的实现说起。 实现过程 我们考虑,在Kruskal算法里,我们每次会合并两个并查集集合。 准确来说是在两个点 $u$、$v$ 之间加一个边权为 $w$ 的无向边。 那么,我们就考虑,在重构树里,我们找到 $u$ 和 $v$ 分别所在的子树,把这两个子树的根拎出来,设为 $u’$ 和 $v’$。 然后,我们就新建一个点 $w$,然后把 $u’$ 和 $v’$ 的父亲设为 $w$。 此时我们就得到了另外一棵树。 比如说这个例子: 而在代码中,我们需要给这些方点一个别的编号,而不是以 $w$ 作为编号,否则会重,并且会炸。 特性 我们讲一些Kruskal重构树的特性: 这棵树一定是二叉树。 原树中的点放到重构树上一定是叶子,重构树上其他点都是原树中的边权。 节点个数一定是 $2n-1$,且 $2n-1$ 一定是根。 如果是最小生成树,那么这棵重构树一定是大根堆1,否则是小根堆。 原图中两个点 $u$、$v$ 之间所有路径上的边权最大值的最小值,就是该图的最小生成树重构树上,$u$ 和 $v$ 的LCA的权值。 尚未想到证明方式 对于一个最小生成树上的点 $x$,其只通过(边权)不超过 $v$ 的边,能到的点集;和 $x$ 在重构树上深度最浅的、权值 $\leq v$ 的点 $y$ 的子树内(叶子)节点集合,是一样的。 这里稍微证明一下。 就是我们根据上面的性质,可以发现,设后者对应集合为 $S$,那么显然 $S$ 内的点,和 $x$ 点,的LCA的权值一定不超过 $v$,显然。 ...