AT_abc141_e.[ABC141E] Who Says a Pun?

普及+/提高

通过率:0%

AC君温馨提醒

该题目为【atcoder】题库的题目,您提交的代码将被提交至atcoder进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

给定一个长度为 NN 的字符串 SS

请你求出所有作为 SS 的连续子串且在 SS 中不重叠地出现至少两次的非空字符串中,最长的长度是多少。

更严格地说,求满足以下条件的正整数 lenlen 的最大值:

  • l1+lenl2l_1 + len \leq l_2
  • S[l1+i]=S[l2+i] (i=0,1,,len1)S[l_1 + i] = S[l_2 + i]\ (i = 0, 1, \ldots, len - 1)

存在整数 l1,l2l_1, l_21l1,l2Nlen+11 \leq l_1, l_2 \leq N - len + 1)使上述条件成立。若不存在这样的 lenlen,请输出 00

输入格式

输入以以下格式从标准输入读入。

NN SS

输出格式

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

输入输出样例

  • 输入#1

    5
    ababa

    输出#1

    2
  • 输入#2

    2
    xy

    输出#2

    0
  • 输入#3

    13
    strangeorange

    输出#3

    5

说明/提示

限制条件

  • 2N5×1032 \leq N \leq 5 \times 10^3
  • S=N|S| = N
  • SS 由小写英文字母组成

样例解释 1

满足条件的字符串有 ababba。这些字符串的最大长度为 22,因此答案为 22。注意,虽然 aba 作为 SS 的连续子串出现了两次,但无法取到满足 l1+lenl2l_1 + len \leq l_2l1l_1l2l_2

样例解释 2

不存在满足条件的非空字符串。

首页