如果不考虑那个奇怪的询问的话,可以简单地用splay树维护序列。但是splay上显然不能维护每种颜色的个数,这样在每个节点上时间和空间都是O(n)的。
我们把给每种颜色的节点单独建一棵splay,每个节点放在两棵splay中,一棵是原序列,一棵是它自己的颜色。接下来考虑如何进行插入、询问和删除操作。
删除操作比较简单,只需要在大splay上找到对应的节点,在两棵树中先旋转到底再自下而上删除。
插入和询问都可以在小splay上走,通过在大splay上的询问就可以知道当前节点在序列中的位置。
复杂度O((n+q)log2</
Codeforces 455D Serega and Fun【解法一】
最新推荐文章于 2021-05-28 11:21:05 发布
该博客介绍了如何利用splay树解决Codeforces 455D问题,通过建立每种颜色的节点来优化操作,使得在删除、插入和询问操作中的时间复杂度达到O((n+q)log2n)。

6174

被折叠的 条评论
为什么被折叠?



