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