USACO 1.3.3 Calf Flac

USACO 1.3.3 Calf Flac

/**/ /*
ID: lorelei3
TASK: calfflac
LANG: C++
*/


#include 
< stdio.h >
#include 
< stdlib.h >
#include 
< string .h >
#include 
< assert.h >
#include 
< ctype.h >


const   int  N  =   21000 ;

char  fulltext[N];
char  text[N];

int  pallen,b;

int  findpal() {
    
char *p, *fwd, *bkwd, *etext = text+strlen(text);
    
int tmp;

    
for(p=text; *p; ++p){
        
for(fwd=p,bkwd=p; fwd<etext && bkwd>=text && *fwd==*bkwd; fwd++, bkwd--);
        bkwd
++;
        tmp
=fwd-bkwd;
        
if(tmp>pallen){
            pallen
=tmp;
            b
=bkwd-text;
        }


        
for(fwd=p,bkwd=p+1; fwd<etext && bkwd>=text && *fwd==*bkwd; fwd++, bkwd--);
        bkwd
++;
        tmp
=fwd-bkwd;
        
if(tmp>pallen){
            pallen
=tmp;
            b
=bkwd-text;
        }

    }

    
return 0;
}


int  main() {
    
int i;
    
char *p, *q, ch;

    FILE 
*fin, *fout;
    fin 
= fopen("calfflac.in""r");
    fout 
= fopen("calfflac.out""w");

    p
=fulltext;
    q
=text;
    
while((ch = getc(fin)) != EOF) {
        
if(isalpha(ch))
            
*q++ = tolower(ch);
        
*p++ = ch;
    }


    
*= '\0';
    
*= '\0';

        
    findpal();

    fprintf(fout, 
"%d\n", pallen);

    
for(i=0, p=fulltext; *p; ++p)
        
if(isalpha(*p))
            
if(i++==b)
                
break;

    
for(i=0; i<pallen && *p; ++p){
        fputc(
*p, fout);
        
if(isalpha(*p))
            i
++;
    }

    fprintf(fout, 
"\n");

    
return 0;
}

你可能感兴趣的:(USACO 1.3.3 Calf Flac)