关于 manacher 的一个小细节

在该算法中,我们需要用到一个数组 hw[i] ,代表 i 的最大回文半径。而且这个半径不包括 i 本身(若串为 ccc 则 hw 为 1)。

这时最终答案为最大的 hw 减一。

为什么要减一呢?最终的串只有两种形式

#c#c#c##c#c#c#c# 。即中间为 # 或中间为 c (#为加入的分隔符,c为原字符串中的一个字符)

可以数一下,这两种情况若设最终答案为 \(ans\) ,则总会有 \(ans + 1\)个分隔符。

所以可得 \(2hw + 1 = ans + (ans + 1)\)

转换后可以得到 \(ans = hw - 1\)

posted @ 2022-11-06 17:17  _maze  阅读(27)  评论(0)    收藏  举报