CF2164H PalindromePalindrome
题目描述
我们定义字符串 $t$ 的幽默值为:在 $t$ 中至少出现两次的最长回文子串的长度。
具体地,对于一个字符串 $t$,只有当以下两个条件同时满足时,字符串 $p$ 才称为 $t$ 的幽默字符串:
1. $p$ 是回文串;
2. 存在至少两个不同的下标 $i \in [1, |t| - |p| + 1]$,使得 $t[i, i + |p| - 1] = p$。
字符串 $t$ 的幽默值定义为:所有 $t$ 的幽默字符串中最大长度。
现给定一个长度为 $n$ 只包含小写英文字母的字符串 $s$ 以及 $q$ 个询问。每个询问包含两个整数 $l_i$、$r_i$,你需要求出 $s[l_i, r_i]$ 的幽默值。
这里 $a[l, r]$ 表示字符串 $a_l,a_{l+1},\ldots,a_r$。
输入格式
第一行包含两个整数 $n$、$q$($1\le n,q\le 5\times10^5$)。
第二行包含一个字符串 $s$。
接下来的 $q$ 行,每行包含两个整数 $l_i$、$r_i$($1\le l_i\le r_i\le n$),表示一次询问。
输出格式
对于第 $i$ 个询问,输出一行答案。
说明/提示
对于第一个询问,下列回文串至少出现了两次:a、aa、aaa、aaaa、b、bb、bbb。最长的是 aaaa,所以幽默值为 $4$。
对于第二个询问,$s[2, 7]$ 的最长幽默字符串之一是 aa。
由 ChatGPT 5 翻译