Pagini recente » Cod sursa (job #571285) | Cod sursa (job #1632376) | Cod sursa (job #3286777) | Cod sursa (job #1838792) | Cod sursa (job #1223874)
#include<cstdio>
#include<vector>
using namespace std;
char A[2000001],B[2000001];
int i,prev,k[2000001],p;
vector <int> v;
int main()
{
freopen("strmatch.in","r",stdin);
freopen("strmatch.out","w",stdout);
gets(A);
gets(B);
int n=1;
for(i=1;A[i]!=0;i++)
{
n++;
prev=k[i-1];
while(A[prev]!=A[i]&&prev>0)
{
prev=k[prev-1];
}
if(A[i]!=A[prev])
k[i]=0;
else
k[i]=prev+1;
//printf("%d->%d\n",i,k[i]);
}
p=0;
for(i=0;B[i]!=0;i++)
{
while(A[p]!=B[i]&&p>0)
{
p=k[p];
}
if(A[p]==B[i])
{
p++;
if(p==n)
{
v.push_back(i-n+1);
p=k[p-1];
}
}
}
printf("%d\n",v.size());
for(i=0;i<v.size();i++)
printf("%d ",v[i]);
return 0;
}