Pagini recente » Cod sursa (job #1656456) | Cod sursa (job #200381) | Cod sursa (job #324636) | Cod sursa (job #2812543) | Cod sursa (job #123583)
Cod sursa(job #123583)
#include<stdio.h>
#include<string.h>
char *s,sir[2000005];
long int L,sol,i,lung[2000005],st,dr,dr0;
int main()
{
FILE *f,*g;f=fopen("pscpld.in","r");g=fopen("pscpld.out","w");
sir[0]='#';
s=&sir[1];fscanf(f,"%s",s);
L=strlen(s);
for(i=L-1;i>=0;i--){ s[2*i+2]=' ';s[2*i+1]=s[i];}
s[0]=' ';
L=2*L;s[L+1]='*';
for(i=1;i<L;i++)
{ dr0=i+lung[i];
while(s[i+lung[i]+1]==s[i-lung[i]-1])lung[i]++;
for(dr=dr0;dr<i+lung[i];dr++)
{ st=2*i-dr;
if(st-lung[st]>=i-lung[i])
{ lung[dr]=lung[st];}
else
lung[dr]=i+lung[i]-dr;
}
sol=sol+(lung[i]+i%2)/2;
}
fprintf(g,"%ld\n",sol);
return 0;
}