Pagini recente » Cod sursa (job #1659812) | Cod sursa (job #2362047) | Cod sursa (job #2369040) | Cod sursa (job #379847) | Cod sursa (job #987402)
Cod sursa(job #987402)
#include <cstdio>
using namespace std;
long n,x,i,rez,y,a[500001],p[500001];
int main () {
freopen("reguli.in","r",stdin);
freopen("reguli.out","w",stdout);
scanf("%ld%ld",&n,&x);
n--;
for(i=1;i<=n;i++)
{
scanf("%ld",&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("%ld\n",a[i]);
return 0;
}