• <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
            題目不難,但是。。。
            首先我的想法是從1到n,left=0,right=1,然后往兩邊數顏色相同的珠子。如果用一個大小為n的數組存字符串,一個很顯然的問題就是當left<0或者right>n-1時就要溢出。所以要用到一個取余的函數
            int cycle(int a,int n)
            {
                return a<0?(a%n+n):(a%n);
            }
            但是這樣確實太麻煩了,寫的代碼也容易出錯,我終于決定重寫了。新的想法是在字符串兩邊各復制一份相同的,這樣就是大小為3×n的字符串,而循環時只需要從n到2×n-1,解決了溢出的問題。(但是我覺得這并不是一個好方法,因為浪費了三倍的空間)。最終的代碼是這樣的,雖然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) 評論(0)  編輯 收藏 引用
            日韩精品无码久久一区二区三| 久久r热这里有精品视频| 久久人人爽人人爽人人AV| 国产99久久久国产精品小说| 伊人丁香狠狠色综合久久| 亚洲国产精品一区二区久久| 国内精品人妻无码久久久影院| 亚洲精品国产字幕久久不卡| 久久久久亚洲AV成人网人人网站 | 国产精品九九久久免费视频| 欧美牲交A欧牲交aⅴ久久| 无码任你躁久久久久久老妇App| 久久久亚洲精品蜜桃臀| 亚洲精品国精品久久99热| 久久人人爽人人爽人人AV东京热| 久久精品无码专区免费东京热 | 国内精品伊人久久久久影院对白 | 一本久久久久久久| 久久久91人妻无码精品蜜桃HD| 青青青青久久精品国产h久久精品五福影院1421 | 伊人久久大香线蕉综合5g| 7777精品伊人久久久大香线蕉| 日韩精品久久久久久免费| 久久亚洲国产欧洲精品一| 久久青青国产| 久久久亚洲裙底偷窥综合 | 久久久久亚洲AV无码专区体验| 国产精品美女久久久久久2018| 色综合合久久天天综合绕视看| 亚洲午夜精品久久久久久app| 久久精品国产网红主播| 午夜精品久久久久9999高清| 国产三级久久久精品麻豆三级| 精品久久久无码中文字幕天天| 一本色道久久综合亚洲精品| 久久国产影院| 亚洲va中文字幕无码久久不卡| 99久久夜色精品国产网站| 婷婷综合久久中文字幕蜜桃三电影 | 国产一区二区三区久久| 无码人妻久久一区二区三区蜜桃|