Pagini recente » Cod sursa (job #1790512) | Cod sursa (job #3261362) | Cod sursa (job #68410) | Cod sursa (job #2573644) | Cod sursa (job #1164177)
#include<fstream>
using namespace std;
ifstream f("numarare.in");
ofstream g("numarare.out");
int i,p,sol,n,a[100010],v[100010];
int main()
{
f>>n>>v[1];
for(i=2;i<=n;++i)
{
f>>v[i];
v[i-1]-=v[i];
}
p=1;
--n;
for(i=1;i<=n;++i)
{
if(i<p+a[p])
a[i]=min(a[2*p-i],p+a[p]-i);
if(i+a[i]>=p+a[p])
{
p=i;
while(i-a[i]-1>=1&&i+a[i]+1<=n&&v[i-a[i]-1]==v[i+a[i]+1])
++a[i];
}
}
sol=n;
for(i=1;i<=n;++i)
sol+=a[i];
g<<sol<<'\n';
return 0;
}