Cod sursa(job #2661680)

Utilizator TudorCretuCretu Tudor Andrei TudorCretu Data 22 octombrie 2020 15:34:13
Problema Reguli Scor 80
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.49 kb
#include <fstream>
using namespace std;
ifstream f("reguli.in");
ofstream g("reguli.out");
int i,n,urm[500005],a[500005],x,y,k,nr;
int main()
{
    f>>n>>x;
    for(i=1;i<n;i++)
    {
        f>>y;
        a[i]=y-x;
        x=y;
    }
    urm[1]=0;
    k=0;
    for(i=2;i<n;i++)
    {
        while(k>0 && a[k+1]!=a[i]) k=urm[k];
        if(a[k+1]==a[i]) k++;
        urm[i]=k;
    }
    nr=n-urm[n-1]-1;
    g<<nr<<'\n';
    for(i=1;i<=nr;i++)
        g<<a[i]<<'\n';
}