#P8631. [蓝桥杯 2015 国 AC] 切开字符串

    ID: 7929 远端评测题 1000ms 512MiB 尝试: 0 已通过: 0 难度: 6 上传者: 标签>2015枚举前缀和Manacher 算法蓝桥杯国赛

[蓝桥杯 2015 国 AC] 切开字符串

题目描述

Pear 有一个字符串,不过他希望把它切成两段。

这是一个长度为 NN105 \le 10^5)的字符串。

Pear 希望选择一个位置,把字符串不重复不遗漏地切成两段,长度分别是 ttNtN-t(这两段都必须非空)。

Pear 用如下方式评估切割的方案:

定义“正回文子串”为:长度为奇数的回文子串。

设切成的两段字符串中,前一段中有 AA 个不相同的正回文子串,后一段中有 BB 个不相同的非正回文子串,则该方案的得分为 A×BA \times B

注意,后一段中的 BB 表示的是:“ ... 非正回文 ... ”,而不是:“ ... 正回文 ... ”。

那么所有的切割方案中,A×BA \times B 的最大值是多少呢?

输入格式

输入第一行一个正整数 NN105 \le 10^5

接下来一行一个字符串,长度为 NN。该字符串仅包含小写英文字母。

输出格式

一行一个正整数,表示所求的 A×BA \times B 的最大值。

10
bbaaabcaba
38

提示

对于 20%20\% 的数据,N100N \le 100

对于 40%40\% 的数据,N1000N \le 1000

对于 100%100\% 的数据,N105N \le 10^5

时限 1 秒, 512M。蓝桥杯 2015 年第六届国赛