Cod sursa(job #2330214)

Utilizator triscacezarTrisca Vicol Cezar triscacezar Data 28 ianuarie 2019 08:28:26
Problema Potrivirea sirurilor Scor 40
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <bits/stdc++.h>

using namespace std;

ifstream f("strmatch.in");
ofstream g("strmatch.out");

int n,m,i,j,k,kmp[2000010];
vector<int> ans;
string A,B;

int main()
{
    f>>A>>B;
    n=A.size();
    m=B.size();
    for(i=2;i<=n;i++)
    {
        while(k&&A[k]!=A[i-1])
            k=kmp[k];
        if(A[k]==A[i-1])
            k++;
        kmp[i]=k;
    }
    k=0;
    for(i=1;i<=m;i++)
    {
        if(ans.size()==1000)break;
        while(k&&A[k]!=B[i-1])
            k=kmp[k];
        if(A[k]==B[i-1])
            k++;
        if(k==n)
            ans.push_back(i-n);
    }
    g<<ans.size()<<'\n';
    for(auto it:ans)
        g<<it<<' ';
    return 0;
}