#L2073. 「JSOI2016」扭动的回文串

    ID: 4778 传统题 1000ms 256MiB 尝试: 1 已通过: 1 难度: 10 上传者: 标签>其他二分查找字符串哈希和哈希表Manacher

「JSOI2016」扭动的回文串

题目描述

JYY 有两个长度均为 NN 的字符串 AABB

一个扭动字符串 S(i,j,k)S(i,j,k)AA 中第 ii 个字符到第 jj 个字符组成的子串与 BB 中第 jj 个字符到第 kk 个字符组成的子串拼接而成。
例如,若 A=XYZA = \text{XYZ}B=UVWB = \text{UVW},则扭动字符串 S(1,2,3)=XYVWS(1,2,3) = \text{XYVW}

JYY 定义一个扭动的回文串为以下情况之一:

  1. AA 中的一个回文串;
  2. BB 中的一个回文串;
  3. 或者某一个回文的扭动字符串 S(i,j,k)S(i,j,k)

现在 JYY 希望找出最长的扭动回文串。


输入格式

  • 第一行包含一个正整数 NN
  • 第二行包含一个长度为 NN 的由大写字母组成的字符串 AA
  • 第三行包含一个长度为 NN 的由大写字母组成的字符串 BB

输出格式

输出一行一个整数,表示最长的扭动回文串的长度。


样例

输入

5
ABCDE
BAECB

输出

5

解释
最佳方案中的扭动回文串如下所示(不在回文串中的字符用 . 表示):

.BC..
..ECB

数据范围

对于所有数据,1N1051 \leq N \leq 10^5