#ZS0076. 字符串匹配

字符串匹配

题目描述

给出两个字符串 s1s_1s2 s_2,若 s1s_1 的区间 [l,r] 子串与 s2s_2 完全相同,则称s2s_2s1s_1 中出现了,其出现位置为l。 现在请你求出 s2s_2s1 s_1 中所有出现的位置, 定义一个字符串 ss borderborderss 的一个非 ss 本身的子串 tt,满足t t 既是 ss 的前缀,又是 ss 的后缀 对于字符串s2 s_2,需要求出 s2s_2 的每个前缀 ss 的最长 borderborder tt' 的长度

输入格式

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

输出格式

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

输入样例

ABABABC
ABA

输出样例

1
3
0 0 1 

提示

对于全部的测试点,保证 1\leqs1|s1|s2|s2|\le 10610^6s1s_1s2s_2 中均只含大写英文字母。