• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-6  評論-2  文章-0  trackbacks-0

            #include <stdio.h>
            #include 
            <stdlib.h>
            int main()
            {
                FILE 
            *fin,*fout;
                fin
            =fopen("beads.in","r");
                fout
            =fopen("beads.out","w");
                
            char *beads;
                
            int n;
                fscanf(fin,
            "%d",&n);
                beads
            =(char *)malloc(3*n*sizeof(char));
                fscanf(fin,
            "%s",beads);
                
            int i,a,b,left,right,sum=0;
                
            for(i=n;i<3*n;++i)
                {
                    beads[i]
            =beads[i-n];
                }
                
            for(i=n;i<2*n;++i)
                {
                    left
            =i;
                    right
            =i+1;
                    
            char ch;

                    
            while(beads[left]=='w'&&left>=0)--left;
                    ch
            =beads[left];
                    
            while(left>0&&(beads[left-1]==ch||beads[left-1]=='w'))--left;
                    a
            =i-left+1;

                    
            while(beads[right]=='w'&&right<3*n)++right;
                    ch
            =beads[right];
                    
            while(right<(3*n-1)&&(beads[right+1]==ch||beads[right+1]=='w'))++right;
                    b
            =right-i;

                    
            if(a+b>sum)sum=a+b;
                    
            if(a>=n||b>=n||a+b>n)sum=n;
                }
                fprintf(fout,
            "%d\n",sum);
                
            return 0;
            }
            首先我的想法是從1到n,left=0,right=1,然后往兩邊數(shù)顏色相同的珠子。如果用一個(gè)大小為n的數(shù)組存字符串,一個(gè)很顯然的問題就是當(dāng)left<0或者right>n-1時(shí)就要溢出。所以要用到一個(gè)取余的函數(shù)。
            但是這樣確實(shí)太麻煩了,寫的代碼也容易出錯(cuò),我終于決定重寫了。新的想法是在字符串兩邊各復(fù)制一份相同的,這樣就是大小為3×n的字符串,而循環(huán)時(shí)只需要從n到2×n-1,解決了溢出的問題。(但是我覺得這并不是一個(gè)好方法,因?yàn)槔速M(fèi)了三倍的空間)。最終的代碼是這樣的,雖然AC了,但總不是那么完美。













            posted on 2010-10-21 14:54 cometrue 閱讀(1286) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            亚洲午夜久久影院| 久久99精品久久久久久野外| 久久久噜噜噜久久中文字幕色伊伊| 久久精品国产亚洲Aⅴ香蕉 | 国产精品VIDEOSSEX久久发布| 亚洲国产成人久久精品影视| 精品久久久一二三区| 久久精品九九亚洲精品| 无码国内精品久久人妻麻豆按摩| 亚洲国产精品无码久久| 91久久成人免费| 久久久噜噜噜久久中文福利| 999久久久国产精品| 久久亚洲精品无码AV红樱桃| 武侠古典久久婷婷狼人伊人| 国产精品久久99| 亚洲精品乱码久久久久久| 久久久久国产日韩精品网站| 国产精品视频久久久| 亚洲综合日韩久久成人AV| 日韩久久无码免费毛片软件| 色综合久久久久| 999久久久无码国产精品| 精品一二三区久久aaa片| 人妻无码久久精品| 精品久久久无码中文字幕| 久久久久久狠狠丁香| 国产精品久久久久影视不卡| 一本久道久久综合狠狠爱| 久久精品青青草原伊人| 久久午夜福利无码1000合集| 亚洲精品tv久久久久久久久久| 久久国产免费| 久久久久亚洲AV成人网人人网站| 7国产欧美日韩综合天堂中文久久久久 | 久久天天躁狠狠躁夜夜96流白浆 | 欧美伊人久久大香线蕉综合69 | 一本久道久久综合狠狠爱| 狠狠综合久久综合88亚洲| 狠狠精品久久久无码中文字幕| 青青青青久久精品国产h久久精品五福影院1421 |