Cod sursa(job #1223874)

Utilizator alecsandrualex cuturela alecsandru Data 29 august 2014 08:38:09
Problema Potrivirea sirurilor Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.95 kb
#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;
}