zoukankan      html  css  js  c++  java
  • USACO 1.3 Calf flac

    /*
    ID: aznfy1
    PROG: calfflac
    LANG: C++
    */
    
    #include<stdio.h>
    #include<string.h>
    #include<iostream>
    #include<ctype.h>
    #include<math.h>
    using namespace std;
    
    char source[20001]={0};
    char cr[20001]={0};
    char line[81];
    int maxlen;int u,v;
    int maxu;int maxv;
    int main()
    {
        freopen("calfflac.in","r",stdin);
        freopen("calfflac.out","w",stdout);
        while(gets(line)!=NULL)
        {
            strcat(source,line);
            cr[strlen(source)-1]=1;
        }
        int len2=strlen(source);
        for(int i=0;i<len2;i++)
        {
            if(!isalpha(source[i])) continue;
            u=v=i;int len=-1;
            while(v>=0&&(u<=(len2-1)))
            {
                if((source[u]!=source[v])&&(fabs(source[u]-source[v])!=32)) break;
                len+=2;
                if(len>maxlen)
                {
                    maxlen=len;
                    maxu=u;
                    maxv=v;
                }
                u++;v--;
                while((u<=(len2-1))&&!isalpha(source[u]))
                u++;
                while(v>=0&&!isalpha(source[v]))
                v--;
            }
            u=i+1;v=i;len=0;
            while(v>=0&&(u<=(len2-1)))
            {
                if((source[u]!=source[v])&&(fabs(source[u]-source[v])!=32)) break;
                len+=2;
                if(len>maxlen)
                {
                    maxlen=len;
                    maxu=u;
                    maxv=v;
                }
                u++;v--;
                while((u<=(len2-1))&&!isalpha(source[u]))
                u++;
                while(v>=0&&!isalpha(source[v]))
                v--;
            }
        }
        printf("%d\n",maxlen);
        for(int i=maxv;i<=maxu;i++) {
            printf("%c",source[i]);
            if(cr[i]==1) printf("\n");
        }
        if(cr[maxu]!=1) printf("\n");
        return 0;
    }
    View Code

    这道题出现了一点问题,刚开始没有写 len2=strlen(source) 导致第八组数据卡住1.6S,因为每次用到这个长度都扫描计算一次,实在太菜,以后不能再犯了。

    大体思路:

    #1.输入:一行一行的输入,每行cat进大数组中,并且记录好该换行的位置,因为输出时需要考虑在哪里输出换行符。

    #2.主程序:从第一位扫描到串尾,假设它是回文串的中心字符,并向两边进行扩展,需要进行总的两次扫描,一次为奇串,一次为偶串。

    扫描中注意以下几点:

              1.不是字母继续下一位枚举

              2.向两边搜索,两个字符字符相等或者互为大小写,则更新为最长子串,否则BREAK,

              3.搜索时,遇到!isalpha应当跳过不管,只看字符,不看符号。

    #3:输出:原样输出,注意输出换行符。

    附上HL神牛的论文

    还没看完

    http://wenku.baidu.com/view/84b69168a45177232f60a29a.html

  • 相关阅读:
    HashMap
    Spring事务异常回滚,捕获异常不抛出就不会回滚(转载) 解决了我一年前的问题
    脏读 不可重复读 幻读
    冒泡优化
    Class.forName的作用以及为什么要用它【转】
    java反射入门
    Java异常分类 转载
    转载 【CSS进阶】伪元素的妙用--单标签之美
    转载文章 利用旋转正方形与图形的组合实现爱心
    Three.js基础学习【修改版】
  • 原文地址:https://www.cnblogs.com/whatthefy/p/3086258.html
Copyright © 2011-2022 走看看