#P10634. BZOJ2372 music

    ID: 10066 Type: RemoteJudge 1000ms 512MiB Tried: 0 Accepted: 0 Difficulty: 5 Uploaded By: Tags>字符串O2优化哈希, hashKMP

BZOJ2372 music

题目描述

最近 A、B 两国发生了一场战争。dick 作为 A 国的军事总指挥,最近非常头痛于己方的情报问题。因为 B 国最近雇佣了 Easy 这一位密码专家来给他们的所有通讯加密。

Easy 非常喜欢唱歌,于是他决定将所有的信号都变成旋律储存起来,比如说 1155665443322111556654433221 就可能是一段加过密的音符,我们用一个等长度的序列来表示它,就变成了 1,1,5,5,6,6,1,1,5,5,6,6,\dots。为了增加密码的保密性,他把加密的乐谱又调整了一下,把某些音调改变了,将原序列 AA 变成 BB,有 A=B|A|=|B|,且对于 ai=aja_i=a_jbi=bjb_i=b_j,对于 ai<aja_i<a_jbi<bjb_i<b_j,对于 ai>aja_i>a_jbi>bjb_i>b_j。例如:1122155775 就可能代表了同一段音符。

最近,dick 截获了一段信号,这段信号中可能包含了某些重要信息。根据以往的经验,dick 已经知道了某些旋律所代表的意义。于是 dick 想知道,对于一段已知的旋律,能不能判断它是否在这段截获的旋律中出现?如果出现了,能否找出它出现的次数及位置呢?

「任务」判断给定旋律在截获旋律中出现的次数及位置。

输入格式

第一行三个正整数 n,m,sn,m,snn 是截获旋律的长度,mm 是已知旋律的长度,所有的旋律都是 1s(s25)1\sim s(s\leq 25) 的正整数。

接下来 nn 行,每行一个整数描述截获的旋律 AA

接下来 mm 行,每行一个整数描述已知的旋律 BB

输出格式

第一行一个整数 tt 表示出现的次数。

然后 tt 行,按照从小到大给出出现时的起始位置 pp,即:A[pp+m1]A[p\dots p+m-1] 等价于 BB

9 6 10
5
6
2
10
10
7
3
2
9
1
4
4
3
2
1
1
3

提示

对于所有数据,保证 1n1051\leq n \leq 10^51m250001\leq m \leq 25000