• <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>

            USACO 2.1 The Castle

            用Floodfill來給每個module著色,統(tǒng)計一下各種顏色的module數(shù)目。
            在拆墻的時候,由于要求最南和最西的,從下向上,從左到右找,這樣就可以滿足條件。
            拆墻的時候,如果墻兩邊的顏色不一樣,則相加看是否最大。比最大值大則更新相應(yīng)信息。

            #include?<iostream>
            #include?
            <fstream>

            using?namespace?std;

            ifstream?fin(
            "castle.in");
            ofstream?fout(
            "castle.out");

            #ifdef?_DEBUG
            #define?out?cout
            #define?in?cin
            #else
            #define?out?fout
            #define?in?fin
            #endif

            int?n,m;
            int?c[50*50];
            int?data[50][50];
            int?colors[50][50];
            int?color_cnt;

            const?int?W?=?1;
            const?int?N?=?2;
            const?int?E?=?4;
            const?int?S?=?8;

            void?color(int?i,int?j,int?color);

            void?solve()
            {
            ????
            in>>m>>n;
            ????
            ????memset(c,
            0,sizeof(0));
            ????memset(colors,
            -1,sizeof(colors));

            ????color_cnt?
            =?0;

            ????
            for(int?i=0;i<n;++i)
            ????????
            for(int?j=0;j<m;++j){
            ????????????
            in>>data[i][j];
            ????????}

            ????
            for(int?i=0;i<n;++i)
            ????????
            for(int?j=0;j<m;++j){
            ????????????
            if(colors[i][j]==-1){
            ????????????????color(i,j,color_cnt
            ++);
            ????????????}
            ????????}

            ????
            out<<color_cnt<<endl;

            ????
            int?largest?=?INT_MIN;

            ????
            for(int?i=0;i<color_cnt;++i){
            ????????largest?
            =?max(largest,c[i]);
            ????}


            ????
            out<<largest<<endl;

            ????largest?
            =?INT_MIN;
            ????
            int?walli,wallj;
            ????
            char?dir;

            ?????
            for(int?j=0;j<m;++j)
            ????????
            for(int?i=n-1;i>=0;--i)
            ????????{
            ?????????????
            if(i-1>=0){
            ????????????????
            if(?colors[i][j]!=colors[i-1][j]){
            ????????????????????
            if(?largest<c[colors[i][j]]+c[colors[i-1][j]]){
            ????????????????????????largest
            =c[colors[i][j]]+c[colors[i-1][j]];
            ????????????????????????walli?
            =?i;
            ????????????????????????wallj?
            =?j;
            ????????????????????????dir?
            =?'N';
            ????????????????????}
            ????????????????}
            ????????????}

            ????????????
            if(j+1<m){
            ????????????????
            if(?colors[i][j]!=colors[i][j+1]){
            ????????????????????
            if(largest<c[colors[i][j]]+c[colors[i][j+1]]){
            ????????????????????????largest?
            =?c[colors[i][j]]+c[colors[i][j+1]];
            ????????????????????????walli?
            =?i;
            ????????????????????????wallj?
            =?j;
            ????????????????????????dir?
            =?'E';
            ????????????????????}
            ????????????????}
            ????????????}

            ???????}

            ????
            out<<largest<<endl;
            ????
            out<<walli+1<<'?'<<wallj+1<<'?'<<dir<<endl;

            }

            void?color(int?i,int?j,int?clr)
            {
            ???
            if(colors[i][j]!=-1)
            ??????
            return;

            ????colors[i][j]?
            =?clr;?
            ????c[clr]
            ++;

            ????
            if((data[i][j]&S)==0&&(i+1<n)){
            ??????color(i
            +1,j,clr);?
            ????}

            ????
            if((data[i][j]&E)==0&&(j+1<m)){
            ????????color(i,j
            +1,clr);
            ????}

            ????
            if((data[i][j]&W)==0&&(j-1>=0)){
            ????????color(i,j
            -1,clr);
            ????}

            ????
            if((data[i][j]&N)==0&&(i-1>=0)){
            ????????color(i
            -1,j,clr);
            ????}
            }

            int?main(int?argc,char?*argv[])
            {
            ????solve();?
            ????
            return?0;
            }



            Compiling...
            Compile: OK

            Executing...
            Test 1: TEST OK [0.000 secs, 2868 KB]
            Test 2: TEST OK [0.022 secs, 2868 KB]
            Test 3: TEST OK [0.000 secs, 2868 KB]
            Test 4: TEST OK [0.000 secs, 2868 KB]
            Test 5: TEST OK [0.000 secs, 2868 KB]
            Test 6: TEST OK [0.000 secs, 2872 KB]
            Test 7: TEST OK [0.000 secs, 2872 KB]
            Test 8: TEST OK [0.011 secs, 2868 KB]

            All tests OK.

            posted on 2009-06-17 23:49 YZY 閱讀(1213) 評論(0)  編輯 收藏 引用 所屬分類: AlgorithmUSACO

            導航

            <2009年6月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            統(tǒng)計

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            精品无码久久久久久久久久| 亚洲国产成人久久笫一页| 久久无码人妻一区二区三区午夜 | 91精品国产色综合久久| 国产精品99久久精品| 国产免费久久精品99久久| 久久婷婷五月综合成人D啪 | 久久无码av三级| 亚洲精品国产第一综合99久久| 久久精品国产99国产精品导航| 色综合合久久天天综合绕视看| 99久久精品国产一区二区| 51久久夜色精品国产| 人妻无码αv中文字幕久久琪琪布| 久久国产精品波多野结衣AV| 亚洲成色WWW久久网站| 亚洲午夜无码AV毛片久久| 伊人热人久久中文字幕| 99久久99久久精品国产片果冻| 久久99精品国产麻豆不卡| 久久久久久亚洲Av无码精品专口| 欧美精品九九99久久在观看| 国内精品久久久久久中文字幕| 7777久久亚洲中文字幕| 亚洲AV日韩精品久久久久久久| 久久精品免费大片国产大片| 成人国内精品久久久久影院| 亚洲愉拍99热成人精品热久久 | 亚洲精品97久久中文字幕无码| 秋霞久久国产精品电影院| 97精品伊人久久大香线蕉app| 久久国产劲爆AV内射—百度| 久久综合九色综合欧美就去吻| 国产成人综合久久精品尤物| A级毛片无码久久精品免费| 97精品国产91久久久久久| 天天躁日日躁狠狠久久| 久久夜色精品国产噜噜亚洲AV| 亚洲精品乱码久久久久久蜜桃图片| 日韩欧美亚洲国产精品字幕久久久| 国产精品成人99久久久久|