题面:洛谷 题解: 还是这个性质:对于每个串而言,本质不同的回文串最多只有O(n)个. 所以我们先求出这O(n)个本质不同的回文串,然后对整个串求一次sa. 然后对于每个回文串,求出它的出现次数,更新答案即可. 如何用后缀数组求一个串的出现次数? 因为每个串都必然是某个后缀的前缀.因此我们先找到这个串x,然后在周围二分,寻找一个最大的区间[l, r]使得区间内每个串与x的LCP都大于等于这个串的长度. 可以证明,这样的区间必然是连续的一个. 因此在周围分别向上向下二分一下最多能延伸到哪,是否可行…