Pagini recente » Cod sursa (job #3231306) | Cod sursa (job #2581007) | Cod sursa (job #241303) | Cod sursa (job #83515) | Cod sursa (job #2352334)
#include <bits/stdc++.h>
#define MAXN 2000010
using namespace std;
string A,B;
int Pa[MAXN],P[MAXN];
int main(){
ifstream cin("strmatch.in");
ofstream cout("strmatch.out");
cin>>A>>B;
int k = 0;
cout<<0;
for (int i = 1; i < A.size(); i++) {
while (A[k] != A[i] && k)
k = k - 1;
if (A[k] == A[i])
k++;
Pa[i] = k;
cout<<Pa[i];
}
int j=0,i=0,l=0;
while(i<B.size()){
if(A[j]==B[i]){
i++;
j++;
}
if(j==A.size()){
P[l++]=i-j;
j=Pa[j-1];
}else if(i<B.size() && A[j]!=B[i]){
if(j!=0)j=Pa[j-1];
else i++;
}
}
cout<<l<<'\n';
l=min(l,1000);
for(int i=0;i<l;i++)cout<<P[i]<<' ';
}