动态点分树

更新日志 2025/10/27:开工。

概念

首先你应当会点分树

动态点分树可以支持每次加一个叶子结点并动态维护点分树结构平衡的数据结构。

思路

利用替罪羊树的思想,考虑 \(\alpha\) 重构。也就是说,每加入一个节点后,先将其点分树上父节点直接视作这个父亲(显然合法)并更新到祖先的信息,枚举其所有祖先,找到深度最低的,满足子树大小超过了父节点子树大小 \(\alpha\) 倍的子树(如果有),并重构整棵子树。重构的话直接对整棵子树重新跑一遍点分治即可。

同替罪羊树思想,\(\alpha\) 大致取 \(0.8\) 可以使总重构点数为 \(n\log n\) 级别,原理我不太懂,毕竟我不会替罪羊树。qwq

有一些可能有用的实现细节,就是对每个点开两个数组顺次存下他的祖先与到其的距离,重构时对子树内每个点的这个动态数组同时弹出,直到弹出要重构的子树根节点为止,那么剩下的就是不用重构的祖先。点分治时把当前分治块内所有点推入当前分治中心及距离即可。

例题

紫荆花之恋

题解

posted @ 2025-10-27 17:09  LastKismet  阅读(8)  评论(0)    收藏  举报