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

            posted on 2010-10-21 14:39 cometrue 閱讀(1178) 評(píng)論(0)  編輯 收藏 引用

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


            综合久久一区二区三区| 伊人色综合久久天天人手人婷 | 久久精品国产亚洲精品2020| 久久久av波多野一区二区| 久久婷婷五月综合色高清| 久久免费视频1| 丁香五月综合久久激情| 久久亚洲私人国产精品vA | 久久久久久久久无码精品亚洲日韩 | 久久九九亚洲精品| 亚洲精品无码久久毛片| 蜜臀久久99精品久久久久久小说| 久久久国产精华液| 午夜精品久久久久成人| 久久99热狠狠色精品一区| 久久久久se色偷偷亚洲精品av | 久久午夜福利电影| 久久99精品国产麻豆蜜芽| 久久精品国内一区二区三区| 亚洲午夜无码AV毛片久久| 99久久精品免费看国产一区二区三区 | 亚洲精品国精品久久99热| 久久成人国产精品| 人妻丰满?V无码久久不卡| 国产精品久久99| 国产精品成人99久久久久91gav | 久久综合久久综合亚洲| 久久婷婷五月综合97色直播| 久久国产精品-久久精品| 97久久久久人妻精品专区 | 久久亚洲国产成人精品无码区| 久久久久亚洲精品天堂| 亚洲国产精品无码久久SM| 99久久人妻无码精品系列| 久久亚洲精品中文字幕三区| 久久精品国产亚洲av麻豆色欲| 777午夜精品久久av蜜臀 | 国产叼嘿久久精品久久| 91视频国产91久久久| 久久99国产精品久久99果冻传媒| 91精品国产91久久久久福利|