Pagini recente » Cod sursa (job #1752239) | Cod sursa (job #823889) | Cod sursa (job #334896) | Cod sursa (job #2558559) | Cod sursa (job #444601)
Cod sursa(job #444601)
#include <stdio.h>
#include <string.h>
FILE *f=fopen("strmatch.in","r"),*g=fopen("strmatch.out","w");
char a[2000005],b[2000005];
int k,i,n,m,pr[2000005],poz[1024];
int main(void)
{
fgets(a,2000004,f);
fgets(b,2000004,f);
n=strlen(a)-2;
m=strlen(b)-2;
k=-1;
pr[0]=-1;
for (i=1;i<=n;i++)
{
while (k>-1 && a[k+1]!=a[i])
k=pr[k];
if (a[k+1]==a[i])
k++;
pr[i]=k;
}
int ok=0;
k=-1;
for (i=0;i<=m && ok==0;i++)
{
while (k>-1 && a[k+1]!=b[i])
k=pr[k];
if (a[k+1]==b[i])
k++;
if (k==n)
poz[++poz[0]]=i-n;
if (poz[0]==1000) ok=1;
}
fprintf(g,"%d\n",poz[0]);
for (i=1;i<=poz[0];i++)
fprintf(g,"%d ",poz[i]);
fprintf(g,"\n");
fclose(g);
return 0;
}