P3435 [POI 2006] OKR-Periods of Words
题目描述
一个**字符串**是由小写英文字母组成的有限序列。特别地,它也可以是空序列(即长度为 $0$ 的序列)。
如果字符串 $A$ 是通过字符串 $B$ 和 $C$ 按顺序连接(中间没有任何间隔符号)得到的,我们表示为 $A=BC$。
如果存在一个字符串 $B$ 使得 $A=PB$,那么字符串 $P$ 是字符串 $A$ 的**前缀**。此外,如果 $P \neq A$ 且 $P$ 不是空字符串,我们称 $P$ 是 $A$ 的**真前缀**。
如果 $Q$ 是 $A$ 的真前缀,并且 $A$ 是字符串 $QQ$ 的前缀(不一定是真前缀),那么字符串 $Q$ 是 $A$ 的**周期**。例如,字符串 `abab` 和 `ababab` 都是 `abababa` 的周期。
字符串 $A$ 的**最大周期**是其最长的周期,如果 $A$ 没有周期,则为空字符串。例如,`ababab` 的最大周期是 `abab`;`abc` 的最大周期是空字符串。
---
任务:
编写一个程序,计算该字符串所有前缀的最大周期长度之和。
输入格式
第一行包含一个整数 $k$,表示字符串的长度。
接下来的一行包含一个由 $k$ 个小写英文字母组成的字符串。
输出格式
单独一行输出一个整数,表示输入字符串所有前缀的最大周期长度之和。
说明/提示
(由 Gemini 2.5 Flash 翻译,人工审核)
### 数据范围
对于所有数据,$1\le k\le10^6$。