青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

superman

聚精會神搞建設 一心一意謀發展
posts - 190, comments - 17, trackbacks - 0, articles - 0
   :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

Section 2.1 - The Castle

Posted on 2009-03-25 11:22 superman 閱讀(126) 評論(0)  編輯 收藏 引用 所屬分類: USACO
  1 #include <iostream>
  2 
  3 using namespace std;
  4 
  5 int n, m;
  6 int castleStructure[50][50];
  7 int castleRegion[50][50];
  8 
  9 int regionCnt;
 10 int areaOfRegions[2500];
 11 
 12 void getRegion(int i, int j)
 13 {
 14     if (castleRegion[i][j] != -1)
 15         return;
 16     castleRegion[i][j] = regionCnt;
 17     if ((castleStructure[i][j] & 1== 0)   //W
 18         getRegion(i, j - 1);
 19     if ((castleStructure[i][j] & 2== 0)   //N
 20         getRegion(i - 1, j);
 21     if ((castleStructure[i][j] & 4== 0)   //E
 22         getRegion(i, j + 1);
 23     if ((castleStructure[i][j] & 8== 0)   //S
 24         getRegion(i + 1, j);
 25 }
 26 
 27 int main()
 28 {
 29     freopen("castle.in""r", stdin);
 30     freopen("castle.out""w", stdout);
 31 
 32     cin >> m >> n;
 33     for (int i = 0; i < n; i++)
 34     for (int j = 0; j < m; j++)
 35         cin >> castleStructure[i][j];
 36 
 37     memset(castleRegion, 255sizeof(castleRegion));
 38 
 39     for (int i = 0; i < n; i++)
 40     for (int j = 0; j < m; j++)
 41         if (castleRegion[i][j] == -1)
 42         {
 43             getRegion(i, j);
 44             regionCnt++;
 45         }
 46 
 47     //ans 1
 48     cout << regionCnt << endl;
 49 
 50     for (int i = 0; i < n; i++)
 51     for (int j = 0; j < m; j++)
 52         areaOfRegions[castleRegion[i][j]]++;
 53 
 54     int maxAreaOfRegions = 0;
 55     for (int i = 0; i < regionCnt; i++)
 56         maxAreaOfRegions >?= areaOfRegions[i];
 57 
 58     //ans 2
 59     cout << maxAreaOfRegions << endl;
 60 
 61     int maxAreaAfterRemoveOneWall = 0;
 62     struct { int x, y, dir; } theWallToRemove;
 63 
 64     for (int j = 0; j < m; j++)
 65         for (int i = n - 1; i >= 0; i--)
 66         {
 67             if ((castleStructure[i][j] & 1== 1 && j - 1 >= 0)   //W
 68             {
 69                 if (castleRegion[i][j] == castleRegion[i][j - 1])
 70                     continue;
 71                 int t = areaOfRegions[castleRegion[i][j]] + areaOfRegions[castleRegion[i][j - 1]];
 72                 if (t > maxAreaAfterRemoveOneWall)
 73                 {
 74                     maxAreaAfterRemoveOneWall = t;
 75                     theWallToRemove.x = i;
 76                     theWallToRemove.y = j;
 77                     theWallToRemove.dir = 1;
 78                 }
 79             }
 80             if ((castleStructure[i][j] & 2== 2 && i - 1 >= 0)   //N
 81             {
 82                 if (castleRegion[i][j] == castleRegion[i - 1][j])
 83                     continue;
 84                 int t = areaOfRegions[castleRegion[i][j]] + areaOfRegions[castleRegion[i - 1][j]];
 85                 if (t > maxAreaAfterRemoveOneWall)
 86                 {
 87                     maxAreaAfterRemoveOneWall = t;
 88                     theWallToRemove.x = i;
 89                     theWallToRemove.y = j;
 90                     theWallToRemove.dir = 2;
 91                 }
 92             }
 93             if ((castleStructure[i][j] & 4== 4 && j + 1 < m)   //E
 94             {
 95                 if (castleRegion[i][j] == castleRegion[i][j + 1])
 96                     continue;
 97                 int t = areaOfRegions[castleRegion[i][j]] + areaOfRegions[castleRegion[i][j + 1]];
 98                 if (t > maxAreaAfterRemoveOneWall)
 99                 {
100                     maxAreaAfterRemoveOneWall = t;
101                     theWallToRemove.x = i;
102                     theWallToRemove.y = j;
103                     theWallToRemove.dir = 4;
104                 }
105             }
106             if ((castleStructure[i][j] & 8== 8 && i + 1 < n)   //S
107             {
108                 if (castleRegion[i][j] == castleRegion[i + 1][j])
109                     continue;
110                 int t = areaOfRegions[castleRegion[i][j]] + areaOfRegions[castleRegion[i + 1][j]];
111                 if (t > maxAreaAfterRemoveOneWall)
112                 {
113                     maxAreaAfterRemoveOneWall = t;
114                     theWallToRemove.x = i;
115                     theWallToRemove.y = j;
116                     theWallToRemove.dir = 8;
117                 }
118             }
119         }
120 
121     //ans 3
122     cout << maxAreaAfterRemoveOneWall << endl;
123     cout << theWallToRemove.x + 1 << ' '
124          << theWallToRemove.y + 1 << ' ';
125     if (theWallToRemove.dir == 1) cout << 'W' << endl;
126     if (theWallToRemove.dir == 2) cout << 'N' << endl;
127     if (theWallToRemove.dir == 4) cout << 'E' << endl;
128     if (theWallToRemove.dir == 8) cout << 'S' << endl;
129 
130     return 0;
131 }
132 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久成人精品无人区| 国产精品乱人伦一区二区 | 亚洲电影中文字幕| 玖玖玖国产精品| 欧美电影资源| 亚洲香蕉在线观看| 性欧美精品高清| 亚洲毛片播放| 欧美在线观看www| 亚洲欧洲在线一区| 欧美精品日韩综合在线| 国产日韩一区二区三区在线| 激情成人av| 在线看日韩欧美| 国产精品久久久久免费a∨| 欧美日韩裸体免费视频| 国产精品视频一二| 国产精品久久久久久久久免费樱桃 | 欧美v日韩v国产v| 国产自产精品| 国产欧美日韩不卡| 开心色5月久久精品| 欧美福利视频一区| 欧美在线高清视频| 欧美精品亚洲一区二区在线播放| 亚洲综合成人婷婷小说| 久久久无码精品亚洲日韩按摩| 99香蕉国产精品偷在线观看| 亚洲欧美福利一区二区| 在线视频亚洲| 欧美日韩精品一区二区| 亚洲高清不卡av| 亚洲欧洲免费视频| 激情国产一区二区| 久久久精品tv| 另类综合日韩欧美亚洲| 国产日韩av一区二区| 亚洲专区在线视频| 欧美一区二区三区精品 | 欧美日韩一区二区视频在线 | 99视频在线观看一区三区| 欧美jizz19hd性欧美| 最新日韩av| 亚洲免费一在线| 国产在线国偷精品产拍免费yy| 午夜在线一区| 91久久国产精品91久久性色| 亚洲欧洲一区二区天堂久久| 欧美福利精品| 99热这里只有成人精品国产| 亚洲欧美日韩国产一区二区| 国产欧美日韩视频一区二区三区| 欧美一区二区三区在线| 亚洲女性喷水在线观看一区| 欧美尤物一区| 99国产精品| 免费久久99精品国产自在现线| 亚洲激情精品| 欧美在线视频二区| 亚洲一区二区在线视频| 一区二区三区精品在线| 久久久国产精品一区| 国产一区二区三区日韩| 狠狠久久亚洲欧美专区| 亚洲国产成人在线播放| 99精品国产热久久91蜜凸| 艳女tv在线观看国产一区| 亚洲人永久免费| 久久精品国产综合| 亚洲欧美日本国产有色| 欧美日韩不卡一区| 亚洲精品在线视频| 欧美在线短视频| 亚洲精品久久久久久久久久久久久| 激情综合网激情| 久久久亚洲精品一区二区三区 | 欧美在线观看视频| 欧美日韩精品免费在线观看视频| 裸体一区二区三区| 国产欧美精品日韩精品| 洋洋av久久久久久久一区| 亚洲淫性视频| 亚洲在线电影| 亚洲欧洲一区二区三区久久| 欧美在线精品免播放器视频| 亚洲影视中文字幕| 欧美日韩在线影院| 欧美高清成人| 狠狠操狠狠色综合网| 亚洲欧美制服另类日韩| 亚洲一区二区三区影院| 麻豆国产精品777777在线| 国产美女精品免费电影| 欧美激情一二三区| 久久亚洲国产成人| 国产一区二区三区四区| 亚洲美女黄色| 一区二区三区欧美亚洲| 欧美成人一区二区在线| 欧美成人免费播放| 亚洲精品中文字幕有码专区| 欧美国产另类| 99这里只有久久精品视频| 亚洲色诱最新| 国产精品激情| 欧美亚洲日本网站| 久久久久久久综合狠狠综合| 国产亚洲精品资源在线26u| 欧美一区二视频| 欧美电影免费观看高清完整版| 亚洲精品国久久99热| 欧美日本中文| 亚洲欧美日韩精品久久亚洲区 | 老司机精品福利视频| 亚洲成人在线视频播放| 欧美好吊妞视频| av成人免费观看| 久久精品人人| 亚洲久久一区二区| 国产精品久久久久久亚洲调教| 性刺激综合网| 亚洲高清一二三区| 亚洲视频网站在线观看| 国产午夜精品久久久久久免费视| 久久久久久久综合| 亚洲国内欧美| 久久精品一区二区三区四区 | 欧美一区二区三区日韩| 在线观看亚洲专区| 欧美性一二三区| 久久这里只精品最新地址| 亚洲毛片视频| 欧美成人自拍| 亚洲女同在线| 亚洲日韩中文字幕在线播放| 国产精品毛片在线| 欧美肥婆在线| 久久xxxx精品视频| 一本一本a久久| 欧美护士18xxxxhd| 久久久另类综合| 亚洲欧美欧美一区二区三区| 亚洲国产成人精品女人久久久| 日韩一区二区精品视频| 狂野欧美激情性xxxx| 亚洲小视频在线| 最新国产の精品合集bt伙计| 国产精品成人一区二区艾草| 男女视频一区二区| 久久精品亚洲一区二区| 亚洲一区二区三区成人在线视频精品| 欧美激情按摩| 欧美电影免费观看高清| 久久先锋影音av| 欧美一区二区在线| 99精品视频免费在线观看| 亚洲高清毛片| **性色生活片久久毛片| 国产一区二区丝袜高跟鞋图片| 国产精品高潮呻吟| 欧美性事免费在线观看| 欧美日韩精品国产| 亚洲精选一区| 亚洲天堂av在线免费观看| 91久久在线| 亚洲日本精品国产第一区| 国产一区二区三区四区| 国产小视频国产精品| 国产日韩精品电影| 国产日韩欧美| 国产日韩欧美日韩大片| 国产欧美精品| 国产综合久久| 狠狠综合久久av一区二区小说 | 欧美自拍偷拍午夜视频| 午夜国产精品视频免费体验区| 亚洲淫性视频| 欧美一级二区| 欧美在线免费观看视频| 欧美专区日韩专区| 午夜国产一区| 久久国产精品久久久久久电车| 亚洲女同在线| 久久精品国产亚洲5555| 久久亚洲综合网| 免费不卡欧美自拍视频| 免费看av成人| 亚洲精品一区二区三区不| 日韩视频不卡中文| 一本高清dvd不卡在线观看| 一区二区三区视频在线| 亚洲一区二区高清视频| 性欧美精品高清| 毛片精品免费在线观看| 欧美日韩播放| 国产亚洲欧美日韩一区二区| 亚洲第一黄色网| 一区二区三区.www| 欧美一级大片在线观看| 欧美+日本+国产+在线a∨观看|