P7856 「EZEC-9」模糊众数 解题报告
P7856 「EZEC-9」模糊众数 解题报告:
题意
给定一个长度为 的序列,一次操作可以将某个数字加一,多次询问一个数 ,求使得 称为序列众数至少要多少次操作。
。
分析
由于没有代码,如果假掉希望有老哥提醒一下我(
使 变成众数很难考虑,不妨假定得到了众数的出现次数 ,此时我们只需保证所有数出现次数不超过 以及 出现次数达到 即可。
按照数字大小从大到小枚举每个数,若一个数出现次数超过了 就将其多余的部分放到后面,询问一个位置只需线段树二分出其前 个数字,可以在 内解决。
若每组询问的 不相同呢?枚举 的取值,找到原序列中出现次数超过 的所有数,将其多余部分丢到后面去。直接实现这一过程会退化到 (枚举总量为 ),但我们可以精细处理此过程。
从大到小枚举 的取值,将多余部分丢到后面时,只需判断是否会新增位置放置多余的数(新增次数大于一也没关系,一个数向后新增位置次数总和等于这个数初始出现次数),这样就做到了 。
事实上,对于每个 ,这个 都是可三分的,于是可以对所有询问整体三分并每次调用上面的算法。(我们不能分治地实现这一过程,而是需要逐层处理)
三分性也很好证明,只需说明在 的过程中,保证所有数出现次数不超过 的新增代价与让 出现次数达到 的新增代价均不降。
可以发现一个数若对 的第一部分产生了贡献,其必然对 的第一部分也产生贡献,于是第一部分不降,第二部分由贪心性显然。
时间复杂度 。
代码
有点难写,先咕着。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类