Cod sursa(job #3042391)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 6 aprilie 2023 07:55:19
Problema Potrivirea sirurilor Scor 14
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.55 kb
#include<fstream>
using namespace std;
ifstream F("strmatch.in");
ofstream G("strmatch.out");
string a,b;
int n,m,i,k,t,v[1000],p[2000001];
int main()
{
    for(F>>a>>b,n=a.size(),i=2;i<n;p[i++]=k) {
        for(;k>0&&a[k+1]!=a[i];k=p[k]);
        if(a[k+1]==a[i])
            ++k;
    }
    for(k=0,i=1;a[i];++i) {
        for(;k>0&&a[k+1]!=b[i];k=p[k]);
        if(a[k+1]==b[i])
            ++k;
        if(k==n-1&&a[0]==b[i-n+1])
            t<1000?v[t]=i-n+1:0,++t;
    }
    for(G<<t<<'\n',i=0;i<min(1000,t);G<<v[i++]<<' ');
	return 0;
}