AT_abc141_e [ABC141E] Who Says a Pun?

题目描述

给定一个长度为 $N$ 的字符串 $S$。 请你求出所有作为 $S$ 的连续子串且在 $S$ 中不重叠地出现至少两次的非空字符串中,最长的长度是多少。 更严格地说,求满足以下条件的正整数 $len$ 的最大值: - $l_1 + len \leq l_2$ - $S[l_1 + i] = S[l_2 + i]\ (i = 0, 1, \ldots, len - 1)$ 存在整数 $l_1, l_2$($1 \leq l_1, l_2 \leq N - len + 1$)使上述条件成立。若不存在这样的 $len$,请输出 $0$。

输入格式

输入以以下格式从标准输入读入。 > $N$ $S$

输出格式

输出作为 $S$ 的连续子串且在 $S$ 中不重叠地出现至少两次的非空字符串中,最长的长度。如果不存在这样的非空字符串,则输出 $0$。

说明/提示

### 限制条件 - $2 \leq N \leq 5 \times 10^3$ - $|S| = N$ - $S$ 由小写英文字母组成 ### 样例解释 1 满足条件的字符串有 `a`、`b`、`ab`、`ba`。这些字符串的最大长度为 $2$,因此答案为 $2$。注意,虽然 `aba` 作为 $S$ 的连续子串出现了两次,但无法取到满足 $l_1 + len \leq l_2$ 的 $l_1$ 和 $l_2$。 ### 样例解释 2 不存在满足条件的非空字符串。 由 ChatGPT 4.1 翻译