#64. KMP 字符串匹配

KMP 字符串匹配

Description

给出两个字符串 s1s_1s2s_2,若 s1s_1的区间[l,r] [l, r] 子串与 s2s_2 完全相同,则称s2 s_2s1s_1 中出现了,其出现位置为 ll。 现在请你求出 s2s_2s1s_1 中所有出现的位置。

定义一个字符串 ssborderborder ss 的一个非 ss 本身的子串t t,满足 tt 既是s s的前缀,又是 ss的后缀。 对于 s2s_2,你还需要求出对于其每个前缀 ss' 的最长 borderborder tt' 的长度。

Format

Input

第一行为一个字符串,即为 s1s_1。 第二行为一个字符串,即为 s2s_2。.

Output

首先输出若干行,每行一个整数,按从小到大的顺序输出 s2s_2s1s_1 中出现的位置。 最后一行输出 s2|s_2| 个整数,第 ii 个整数表示 s2s_2的长度为i i的前缀的最长border border 长度。

Samples

ABABABC
ABA
1
3
0 0 1