Cod sursa(job #2673634)

Utilizator BalasaRaduBalasa Radu BalasaRadu Data 17 noiembrie 2020 13:13:45
Problema Reguli Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.58 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("reguli.in");
ofstream fout("reguli.out");
long long s[500009],prefix[500009],n,x,y,first,j,i;
int main()
{
        fin>>n>>first>>x;
    s[1]=x-first;
    for(i=3;i<=n;i++)
    {
        fin>>y;
        s[i-1]=y-x;
        x=y;
    }
    j=1;
    prefix[1]=1;
    for(i=2;i<n;i++)
    {
        while(j>1&&s[j]!=s[i])
            j=prefix[j-1];
        if(s[j]==s[i])
            j++;
        prefix[i]=j-1;
    }
        fout<<n-prefix[n-1]-1<<'\n';
   for(i=1;i<n-prefix[n-1];i++)
        fout<<s[i]<<' ';
}