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

            misschuer

            常用鏈接

            統(tǒng)計(jì)

            積分與排名

            百事通

            最新評(píng)論

            hdu 2819 Swap

            //做這道題很郁悶, 一開始以為計(jì)算行列式值為1.怎么做都不對(duì). 后來發(fā)現(xiàn)只需要斜線都為1即可.
            //就會(huì)想到二分圖的完全匹配

            #include <iostream>
            #include <queue>
            #define MAXN 105
            using namespace std;

            typedef struct {
                
                int u, v;
            }change;

            int n;
            int re[MAXN][MAXN];
            bool chk[MAXN];
            int match[MAXN];


            int find (int x) {
               
                int i;
                for (i = 1;i <= n;++ i) {
                   
                    if (re[ x ][ i ] && !chk[ i ]) {
                        //若x與i相連,且i不在增廣路上             
                        chk[ i ] = true;
                        if (!match[ i ] || find(match[ i ])) {
                            //若i還沒有匹配,或從i的匹配項(xiàng)有增廣路
                            match[ i ] = x;
                            return 1;
                        }  
                    }
                }  
               
                return 0;
            }

            void init() {

                memset(match , 0 , sizeof(match));
            }

            bool res() {
               
                int i, j, m, k, t;
               
                for(i = 1; i <= n; ++ i) {
                   
                    for(j = 1; j <= n; ++ j) {
                       
                        scanf("%d", &re[ i ][ j ]);
                    }
                }       
               
                init();
                for (i = 1;i <= n;++ i) {          
                   
                    memset(chk , 0 , sizeof(chk));
                    if (!find(i)) return false;
                }
               
                queue<change> Q;
                change p;
               
                for (j = 1; j <= n; ++ j) {
                   
                    m = j;
                    for (k = j; k <= n; ++ k) if (match[ k ] <= match[ m ]) m = k;

                    if (m != j) {
                       
                        p.u = m; p.v = j;
                        Q.push(p);
                        t = match[ m ];
                        match[ m ] = match[ j ];
                        match[ j ] = t;
                    }
                }
               
                printf("%d\n", Q.size());
               
                while(!Q.empty()) {
                   
                    p = Q.front();
                    Q.pop();
                    printf("C %d %d\n", p.u, p.v);
                }
                return true;
            }

            int main() {
               
                while (~scanf("%d", &n)) {
                   
                    if(!res()) puts("-1"); 
                }    
                return 0;
            }

             

            posted on 2011-03-19 20:03 此最相思 閱讀(344) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久夜色精品国产噜噜麻豆| 久久精品国产亚洲一区二区| 久久99国产一区二区三区| 日韩久久久久久中文人妻| 久久久久久久亚洲Av无码| 久久久这里有精品| 国产产无码乱码精品久久鸭| 亚洲AV日韩AV天堂久久| 色偷偷88888欧美精品久久久| 综合久久一区二区三区 | 久久精品国产一区二区电影| 久久综合九色综合久99| 久久亚洲欧美日本精品| 久久福利青草精品资源站免费| 97r久久精品国产99国产精| 久久婷婷国产综合精品| 久久99精品国产| 精品久久人人做人人爽综合| 亚洲国产精品成人AV无码久久综合影院 | 久久se精品一区精品二区| 94久久国产乱子伦精品免费| 久久99久久成人免费播放| 99久久99久久精品国产片果冻| 久久久久国产一级毛片高清板| 亚洲精品成人网久久久久久| 97久久国产综合精品女不卡| 成人免费网站久久久| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 久久国产免费| 亚洲国产精品18久久久久久| 久久久中文字幕| 亚洲国产精品综合久久一线| 91精品国产乱码久久久久久 | 久久久精品久久久久特色影视| 久久久久亚洲av无码专区喷水 | 久久精品国产亚洲av麻豆小说| 亚洲欧美另类日本久久国产真实乱对白| 99久久婷婷国产综合精品草原| 久久亚洲春色中文字幕久久久 | 久久强奷乱码老熟女| 国产ww久久久久久久久久|