[ARC088C] Papple Sort
首先,回文假如只考虑 2 个字符,那么它是相对的。
即 A...A,我们只需要考虑 A 是否能匹配到 A。
考虑一个字符的移动代价,显然假如在 ,那么全局移动代价就是 。
对于 A1...A2...A3...A4 这种情况,显然 A1,A4匹配,A2,A3匹配最优。即,能包含不交叉。
考虑扫描线的形式,将每个对应字符都移动到相对位置上的 n,由于当 扫描线经过 i 时将 i 的对应字符移动到 n ,并消除 i,n 的贡献。那么接下来,x 的对应字符 的移动代价就是 n-y-1。即每次的 n 只是为了查询方便,但实际上这个代价可能移动不到 n 只是对于当前扫描线来说是 n (边界)。
那么考虑长度为奇数的回文串,一定有且仅有一个奇数出现次数的字符,那么这个字符一定是在中点。
但全局中点是 ,显然在扫描线的过程中如果将这个字符移动后的位置看成全局中点是不行的。需要考虑相对中点的位置或者移动代价。我们假如现在有 那么中点位置就是 ,那么实际上代价也相当于这样,即 ,就是移动代价。
至于动态维护相对位置的,可以使用树状数组。
实际上,我认为这是一种从相对上进行考虑的想法。
__EOF__

本文作者:F x o r G
本文链接:https://www.cnblogs.com/xugangfan/p/15128981.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/xugangfan/p/15128981.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】