• <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著色,統計一下各種顏色的module數目。
            在拆墻的時候,由于要求最南和最西的,從下向上,從左到右找,這樣就可以滿足條件。
            拆墻的時候,如果墻兩邊的顏色不一樣,則相加看是否最大。比最大值大則更新相應信息。

            #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 閱讀(1217) 評論(0)  編輯 收藏 引用 所屬分類: AlgorithmUSACO

            導航

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

            統計

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            狠狠久久亚洲欧美专区| 婷婷久久精品国产| 亚洲综合久久综合激情久久| 久久青青草原综合伊人| 久久精品国产99久久久香蕉| 99久久这里只精品国产免费| 久久精品无码一区二区无码| 久久www免费人成精品香蕉| 久久福利资源国产精品999| 少妇高潮惨叫久久久久久| 精品人妻伦一二三区久久| 精品久久久久久国产| 久久国产视屏| www.久久热.com| 久久久久99这里有精品10| 精品久久久久久| 人妻精品久久无码专区精东影业| 国产99久久久国产精免费| 蜜臀av性久久久久蜜臀aⅴ麻豆| 国产高清国内精品福利99久久| 久久精品中文字幕一区| 欧美日韩中文字幕久久久不卡| 久久久久久无码Av成人影院| 老男人久久青草av高清| 久久久久噜噜噜亚洲熟女综合| 久久99精品国产自在现线小黄鸭| 伊人久久精品影院| 手机看片久久高清国产日韩| 一本久久久久久久| 日本道色综合久久影院| 国产情侣久久久久aⅴ免费| 一本色道久久99一综合| 亚洲国产天堂久久综合| 久久久噜噜噜久久| 思思久久99热免费精品6| 亚洲国产日韩欧美久久| 亚洲日韩欧美一区久久久久我| 欧美午夜A∨大片久久| 麻豆精品久久久久久久99蜜桃| 久久人人爽人人爽人人爽| 国产精品久久久久蜜芽|