Cod sursa(job #989020)

Utilizator DaNutZ2UuUUBB Bora Dan DaNutZ2UuU Data 24 august 2013 16:40:38
Problema Reguli Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.65 kb
#include <cstdio>
  
using namespace std;
  
long long a[500001],x,y;
  
long n,i,rez,p[500001];
  
int main () {
      
    freopen("reguli.in","r",stdin);
    freopen("reguli.out","w",stdout);
      
    scanf("%ld%lld",&n,&x);
    n--;
      
    for(i=1;i<=n;i++)
    {
        scanf("%lld",&y);
        a[i]=y-x;
        x=y;
    }
      
    int k=0;
    p[1]=0;
    for(i=2;i<=n;i++)
    {
        while(k>0 && a[k+1]!=a[i])
            k=p[k];
        p[i]=(k+=(a[k+1]==a[i]));
    }
    rez=n-p[n];
      
    printf("%ld\n",rez);
      
    for (i=1;i<=rez;++i)
        printf("%lld\n",a[i]);
      
    return 0;
}