Pagini recente » Cod sursa (job #1224046) | Cod sursa (job #2576291) | Cod sursa (job #2654052) | Cod sursa (job #2870604) | Cod sursa (job #2626672)
#include <bits/stdc++.h>
using namespace std;
ifstream r("strmatch.in");
ofstream w("strmatch.out");
string a, b;
int p[2000005], n, m, nr;
bool viz[2000005];
void pref()
{
p[0]=0;
int cnt=0, ans=1;
while (ans<n)
{
if (a[ans] == a[cnt])
{
cnt++;
p[ans] = cnt;
ans++;
}
else
{
if (cnt != 0)
{
cnt = p[cnt - 1];
}
else
{
p[ans] = 0;
ans++;
}
}
}
}
void kmp()
{
int i=0, j=0;
while(j<m)
{
if(a[i]==b[j])
{
i++;
j++;
}
if(i==n)
{
viz[j-i]=1;
nr++;
i=p[i-1];
}
else
{
if(j<m && a[i] != b[j])
{
if(i!=0)
{
i=p[i-1];
}
else
{
j++;
}
}
}
}
}
int main(void)
{
r>>a;
r>>b;
n=a.size(), m=b.size();
pref();
kmp();
w<<nr<<"\n";
for(int i=0; i<m && nr>0; i++)
{
if(viz[i]==1){
w<<i<<" ";
nr--;
}
}
return 0;
}