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

            導航

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

            統計

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            亚洲国产精品久久| 久久综合给合久久狠狠狠97色69| 人妻丰满AV无码久久不卡| 久久99国产综合精品女同| 亚洲天堂久久精品| 精品国产乱码久久久久久人妻| 国内精品人妻无码久久久影院 | 国产精品久久久久久久| 久久国产综合精品五月天| 久久久噜噜噜久久中文字幕色伊伊| 亚洲国产成人久久综合碰碰动漫3d| 久久久久99这里有精品10| 99久久99久久| 亚洲国产精品18久久久久久| 色婷婷噜噜久久国产精品12p| 久久精品国产影库免费看| 久久久无码精品亚洲日韩蜜臀浪潮| 日日狠狠久久偷偷色综合免费| 93精91精品国产综合久久香蕉| 成人久久精品一区二区三区| 亚洲午夜久久久影院| 久久99九九国产免费看小说| 欧美久久亚洲精品| 久久996热精品xxxx| 国产精品99久久不卡| 99久久精品国产麻豆| 丁香五月网久久综合| 久久超乳爆乳中文字幕| 精品久久久久中文字幕日本| 日产精品久久久一区二区| 国产精品99久久久精品无码| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久综合亚洲色HEZYO国产| 成人精品一区二区久久| 丁香久久婷婷国产午夜视频| 激情五月综合综合久久69| 久久国产影院| 久久久久亚洲av成人网人人软件| 国产成人无码精品久久久性色| 久久99久久99精品免视看动漫| 影音先锋女人AV鲁色资源网久久|