Examples

P8330 [ZJOI2022] 众数 解题报告

P8330 [ZJOI2022] 众数 解题报告:

更好的阅读体验

题意

给定一个长度为 \(n\) 的序列,你能对它进行一次区间加,最大化众数出现次数。

\(1\leqslant n\leqslant 2\times 10^5\)

分析

ZJOI T2,传统签到题!场外选手来口胡一下。

显然答案的形态就是 aaabbbaaa,考虑对颜色出现次数根号分治:

  • a/b 存在一个是大颜色:枚举每一个大颜色,扫一遍序列,对每种颜色维护一个极长的 aaabbb 段以及一个 bbbaaa 段即可。
  • a/b 均为小颜色:枚举处于外面的颜色,那么问题转化为 \(O(n\sqrt n)\) 次区间众数。但此时众数大小不超过根号,我们将询问有序地挂在右端点,枚举众数出现次数,移动右端点并维护符合条件最靠后的左端点,弹符合要求的询问就好了。

这样就做到了 \(O(n\sqrt n)\)

代码

咕了。

posted @ 2022-05-03 21:36  xiaoziyao  阅读(247)  评论(5编辑  收藏  举报