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

Why so serious? --[NKU]schindlerlee

2010年02月07日星期日.sgu190 二分圖

2010年02月07日星期日.sgu190
sgu190:
一開始想到的竟然是狀態(tài)壓縮dp,然后一看n,貌似大了點。
然后怎么想也沒思路,上網(wǎng)看看,才知道原來二分圖還可以這么用,我怎么從來也沒想到呢。。。。

將圖像國際象棋棋盤那樣黑白染色,然后給對于每個顏色給每個格子一個編號。
然后選一個染色,對每個格子和他旁邊的格子建邊,這樣構(gòu)成一個二分圖。
求出最大的匹配數(shù),然后再按照題目的猥瑣要求輸出即可。

注意 題目中棋盤的格式是這個樣子的。
(2,1) (2,2)
(1,1) (1,2)
左下角是(1,1)
如果按照平常的左上角是(1,1)來搞,需要注意一下輸出

  1 
  2 int g[801][801],n,P;
  3 const int BLACK = 1;
  4 const int WHITE = 2;
  5 const int REMOVED = 3;
  6 int num[41][41],bsp,wsp,cnt;
  7 int board[41][41];
  8 int bcoord[41*41][2];
  9 int wcoord[41*41][2];
 10 int vis[801];
 11 int L[801],R[801];
 12 
 13 bool make_graph()
 14 {
 15   int i,j;cnt = 0;
 16   for (i = 1;i <= n;i++) {
 17       for (j = 1;j <= n;j++) {
 18           if (board[i][j] != REMOVED) {
 19               cnt ++;
 20               if ((i+j)%2==1) {
 21                   board[i][j] = WHITE;
 22                   wcoord[wsp][0= i, wcoord[wsp][1= j;
 23                   num[i][j] = wsp++;
 24               }else {
 25                   board[i][j] = BLACK;
 26                   bcoord[bsp][0= i, bcoord[bsp][1= j;
 27                   num[i][j] = bsp++;
 28               }
 29           }
 30       }
 31   }
 32   for (i = 1;i <= n;i++) {
 33       for (j = 1;j <= n;j++) {
 34           if (board[i][j] == BLACK) {
 35               if (board[i+1][j] == WHITE) g[num[i][j]][num[i+1][j]] = 1;
 36               if (board[i][j+1== WHITE) g[num[i][j]][num[i][j+1]] = 1;
 37               if (board[i-1][j] == WHITE) g[num[i][j]][num[i-1][j]] = 1;
 38               if (board[i][j-1== WHITE) g[num[i][j]][num[i][j-1]] = 1;
 39           }
 40       }
 41   }
 42   return true;
 43 }
 44 
 45 bool dfs(int u) {
 46   for (int v = 0;v < wsp;v++) {
 47       if (g[u][v] && !vis[v]) {
 48           vis[v] = true;
 49           if (R[v] == -1 || dfs(R[v])) {
 50               L[u] = v;
 51               R[v] = u;
 52               return true;
 53           }
 54       }
 55   }
 56   return false;
 57 }
 58 
 59 int MaxMatch()
 60 {
 61   int i,res = 0;
 62   memset(L,-1,sizeof(L));
 63   memset(R,-1,sizeof(R));
 64 
 65   for (i = 0;i < bsp;i++) {
 66       if (L[i] == -1) {
 67           memset(vis,0,sizeof(vis));
 68           if (dfs(i)) {
 69               res++;
 70           }
 71       }
 72   }
 73   return res;
 74 }
 75 
 76 int out[801][2],top;
 77 bool proc()
 78 {
 79   make_graph(); if (cnt & 1) { return false; }
 80   if (bsp == 0 || wsp == 0) { return false; }
 81   if (bsp != wsp) { return false; }
 82   return (MaxMatch() * 2 == cnt);
 83 }
 84 
 85 int main()
 86 {
 87   int i,j,k,a,b;
 88   scanf("%d%d",&n,&P);
 89   for (i = 0;i < P;i++) {
 90       scanf("%d%d",&a,&b);
 91       board[a][b] = REMOVED;
 92   }
 93   if (proc()) {
 94       printf("Yes\n");
 95       top = 0;
 96       for (i = 0;i < bsp;i++) {
 97           if (bcoord[i][1== wcoord[L[i]][1]) {
 98               if (bcoord[i][0< wcoord[L[i]][0]) {
 99                   out[top][0= bcoord[i][0];
100                   out[top][1= bcoord[i][1];
101                   top++;
102               }else {
103                   out[top][0= wcoord[L[i]][0];
104                   out[top][1= wcoord[L[i]][1];
105                   top++;
106               }
107           }
108       }
109 
110       printf("%d\n",top);
111       for (i = 0;i < top;i++) { printf("%d %d\n",out[i][0],out[i][1]); }
112 
113       top = 0;
114       for (i = 0;i < bsp;i++) {
115           if (bcoord[i][0== wcoord[L[i]][0]) {
116               if (bcoord[i][1< wcoord[L[i]][1]) {
117                   out[top][0= bcoord[i][0];
118                   out[top][1= bcoord[i][1];
119                   top++;
120               }else {
121                   out[top][0= wcoord[L[i]][0];
122                   out[top][1= wcoord[L[i]][1];
123                   top++;
124               }
125           }
126       }//http://m.shnenglu.com/schindlerlee
127       printf("%d\n",top);
128       for (i = 0;i < top;i++) { printf("%d %d\n",out[i][0],out[i][1]); }
129   }else {
130       printf("No\n");
131   }
132 
133 
134   return 0;
135 }
136 
137 

posted on 2010-02-07 15:06 schindlerlee 閱讀(1040) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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久久久免费动漫| 亚洲香蕉成视频在线观看 | 亚洲精品精选| 亚洲第一毛片| 亚洲精品黄色| 亚洲一区亚洲| 久久国产精品久久国产精品| 久久久噜噜噜久久人人看| 久久米奇亚洲| 亚洲人体一区| 亚洲区一区二区三区| 中文久久精品| 久久精品国产亚洲一区二区三区| 久久嫩草精品久久久精品| 欧美国产日韩免费| 国产精品女主播| 亚洲国产精品毛片| 午夜精品一区二区三区电影天堂| 久久中文久久字幕| 亚洲六月丁香色婷婷综合久久| 亚洲自拍偷拍色片视频| 免费成人小视频| 国产乱码精品一区二区三区不卡| 亚洲福利在线视频| 香蕉久久夜色| 亚洲人成亚洲人成在线观看图片 | 一本大道久久精品懂色aⅴ| 亚洲女人天堂av| 亚洲成色精品| 久久成人免费电影| 欧美午夜不卡在线观看免费| 国产精品久久毛片a| 韩国成人精品a∨在线观看| 亚洲日本va午夜在线影院| 一区二区av在线| 欧美一区二区视频网站| 欧美**字幕| 亚洲无亚洲人成网站77777| 久久国产精品99精品国产| 欧美精品啪啪| 国产日韩欧美成人| 夜夜嗨av一区二区三区| 亚洲自拍都市欧美小说| 欧美伊人久久大香线蕉综合69| 美女精品在线观看| 亚洲高清免费| 欧美一级在线亚洲天堂| 久久五月婷婷丁香社区| 一区二区欧美激情| 欧美人牲a欧美精品| 亚洲国产日韩在线一区模特| 欧美在线看片a免费观看| 日韩视频―中文字幕| 久久久精品国产一区二区三区| 国产精品乱看| 亚洲一区日本| 一区二区三区免费在线观看| 欧美激情精品久久久久久久变态| 亚洲国产成人久久综合| 久久久国产一区二区| 亚洲女性裸体视频| 国产一区二区黄色| 久久精品天堂| 久久riav二区三区| 激情文学综合丁香| 久久综合影视| 欧美激情第六页| 日韩午夜电影av| 亚洲精品视频在线播放| 欧美日韩免费| 性欧美长视频| 久久国产福利| 亚洲国产视频直播| 亚洲国产精品久久精品怡红院| 欧美激情视频一区二区三区不卡| 亚洲精品一区二| 日韩视频久久| 国产精品视频成人| 久久久久青草大香线综合精品| 欧美在线视频观看| 在线观看成人av| 91久久精品日日躁夜夜躁欧美 | 国产一区二区精品丝袜| 亚洲欧美国产高清va在线播| 日韩视频免费观看高清在线视频 | 国产视频自拍一区| 久久精品五月| 小嫩嫩精品导航| 国产女主播一区二区三区| 亚洲直播在线一区| 午夜精品福利视频| 国产日韩精品久久| 久久成人精品一区二区三区| 中文高清一区| 国产精品日本| 先锋资源久久| 亚洲欧美影院| 狠狠色综合网| 欧美本精品男人aⅴ天堂| 麻豆精品一区二区综合av| 亚洲第一精品电影| 亚洲无毛电影| 亚洲综合视频一区| 国产一区二区三区电影在线观看 | 美女视频一区免费观看| 欧美日韩国产在线看| 欧美影院久久久| 欧美成人午夜免费视在线看片 | 欧美亚洲视频一区二区| 亚洲精品自在在线观看| 午夜精品视频网站| 99ri日韩精品视频| 久久久99免费视频| 一区福利视频| 欧美一区二区三区视频免费| 99国产精品国产精品毛片| 欧美综合国产精品久久丁香| 一区二区三区日韩| 久热精品视频| 久久成人免费日本黄色| 美国成人直播| 亚洲一区二区视频在线观看| 香蕉视频成人在线观看| 亚洲精品一二区| 午夜精品在线| 亚洲伦理一区| 欧美在线中文字幕| 99国产精品国产精品毛片| 亚洲欧美一区二区视频| 91久久精品一区二区别| 一区二区三区久久精品| 亚洲电影在线播放| 亚洲性人人天天夜夜摸| 亚洲激情一区| 午夜视频一区| 亚洲午夜在线观看| 欧美日本久久| 欧美成人黄色小视频| 国产精品日韩在线观看| 亚洲黄色一区二区三区| 国产亚洲美州欧州综合国| 日韩一区二区精品| 亚洲欧洲在线看| 欧美诱惑福利视频| 亚洲永久网站| 欧美成人免费网| 男女激情视频一区| 在线观看精品视频| 欧美亚洲综合网| 欧美一区二区三区精品电影| 欧美视频久久| 亚洲美女啪啪| 99热在这里有精品免费| 久久综合国产精品| 久久亚洲国产精品一区二区| 国产伦精品一区二区三区免费迷 | 99re亚洲国产精品| 欧美国产一区二区在线观看| 久久综合久色欧美综合狠狠| 久久婷婷国产麻豆91天堂| 久久国产精彩视频| 欧美国产成人精品| 亚洲福利电影| 一区二区三区视频在线观看 | 欧美人与禽性xxxxx杂性| 一区二区欧美在线观看| 久久久亚洲高清| 亚洲精品少妇30p| 国产精品v日韩精品v欧美精品网站| 中文在线不卡| 久久久美女艺术照精彩视频福利播放 | 亚洲欧美日韩成人| 黄网站免费久久| 欧美精品1区2区| 亚洲永久免费av| 免费成人高清在线视频| 99亚洲一区二区| 国产午夜精品全部视频播放| 久久欧美中文字幕| 99成人在线| 蜜臀91精品一区二区三区| 亚洲特级毛片| 亚洲电影免费观看高清完整版在线观看| 欧美韩国在线| 欧美一区二区精品| 99riav国产精品| 蜜桃久久av一区| 先锋a资源在线看亚洲| 亚洲国产成人在线| 国产欧美日韩三级| 欧美激情一区二区在线| 欧美在线观看网站| 一区二区三区高清在线| 欧美在线播放视频| 亚洲电影免费在线| 欧美日韩一区二区三区在线| 午夜精品久久久久久久99热浪潮 | 亚洲精品一区二区三区樱花| 欧美日韩亚洲天堂| 欧美一区国产一区|