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

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數(shù)據(jù)加載中……

hust 1017 Exact Cover (Dancing Links)

/*
從昨天下午就開始搞,今天中午才搞定,Dancing Links 果然高深
神奇的雙向環(huán)形十字鏈表······轉的頭暈了-_-||不過蠻有成就感的^v^
記錄一下解題過程,先反反復復看了一遍Donald E.Knuth的論文,就開始攻hust 1017這道題目,
題目意思很明確:
給定一個由0和1組成的矩陣,是否能找到一個行的集合,使得集合中每一列都恰好包含一個1。

論文中有詳細解答,具體思路就是:
1. 任意選擇一列c,然后刪除它(這個刪除并不是普通的把這一列刪除,而是要將這一列中有1的格子所在的行全部刪除)
2. 然后對這一列上有1的每一行進行枚舉,當枚舉到第i行時
   該行上所有有1的列j全部刪除(同上刪除法)
3. 然后遞歸進入下一次,直到所有的列均被刪除則有解
4. 恢復對j的刪除
5. 恢復對c的刪除
*/


#include 
<iostream>

using namespace std;

struct point {
    
int L;
    
int R;
    
int U;
    
int D;
    
int Sum;
    
int x, y;
}
p[ 1010 * 1010 ];

int n, m;
int i, j, k;
int map[1001][1001];
int sor[1001];
int flag;
int stack[1001], top;

int Num(int x, int y) {
    
return x * 1001 + y;
}

    
//刪除c列
void CoverCol(int c) {
    
int i, j;

    p[ p[ c ].R ].L 
= p[ c ].L;
    p[ p[ c ].L ].R 
= p[ c ].R;
    
//刪除c列中每個有1的行
    i = c;
    
for(i = p[i].D; i != c; i = p[i].D) {
        j 
= i;
        p[ p[i].y ].Sum 
--;
        
for(j = p[j].R; j != i; j = p[j].R) {
            p[ p[j].D ].U 
= p[ j ].U;
            p[ p[j].U ].D 
= p[ j ].D;
        }

    }

}

    
//恢復c列
void Release(int c) {
    
int i, j;

    p[ p[ c ].R ].L 
= c;
    p[ p[ c ].L ].R 
= c;
    
//恢復c列中每個有1的行
    i = c;
    
for(i = p[i].U; i != c; i = p[i].U) {
        j 
= i;
        p[ p[i].y ].Sum 
++;
        
for(j = p[j].L; j != i; j = p[j].L) {
            p[ p[j].D ].U 
= j;
            p[ p[j].U ].D 
= j;
        }

    }

}


int dfs(int k) {
    
int i, j, l, m;

    
if(flag) return 1;

    
//得解輸出
    if(p[ 0 ].R == 0{
        printf(
"%d", top);
        
for(i = 0; i < top; i++)
            printf(
" %d", stack[i]);
        puts(
"");
        flag 
= 1;
        
return 1;
    }


    
int c = 0;          //每次取出沒有被覆蓋的并且1的個數(shù)最小的一列
    int Min = INT_MAX;
    i 
= c;

    
for(i = p[i].R; i ; i = p[i].R) {
        
if(p[ p[i].y ].Sum < Min) {
            Min 
= p[ p[i].y ].Sum;
            c 
= i;
        }

    }



    
//將這一列刪除
    CoverCol(c);
    i 
= c;
    
//枚舉c列中的每一行
    for(i = p[i].D; i != c; i = p[i].D) {
        
//p[i].x 作為當前枚舉的行,進棧
        stack[ top++ ] = p[i].x;
        j 
= i;

        
//對于該枚舉的行,刪除該行上1的格子所在的列
        for(j = p[j].R; j != i; j = p[j].R) {
            CoverCol(p[j].y);
        }

        
if ( dfs(k+1) )
            
return 1;

        
//對于該枚舉的行,恢復該行上1的格子所在的列
        j = i;
        
for(j = p[j].L; j != i; j = p[j].L) {
            Release(p[j].y);
        }

        top 
--;
    }

    
//恢復c
    Release(c);
    
return 0;
}


int main() {

    
int T = 0;
    
while(scanf("%d %d"&n, &m) != EOF) {
        
        T 
++;

        
for(i = 1; i <= n; i++{
            scanf(
"%d"&k);
            
for(j = 0; j < k; j++{
                scanf(
"%d"&sor[j]);
                map[i][sor[j]] 
= T;
            }


            
int lef = Num(i, sor[0]);
            
int rig = Num(i, sor[k-1]);

            p[ lef ].L 
= rig;
            p[ lef ].x 
= i;
            p[ lef ].y 
= sor[0];
            
            
for(j = 1; j < k; j++{
                
int cur = Num(i, sor[j]);
                p[ Num(i, sor[j
-1]) ].R = cur;

                p[ cur ].L 
= Num(i, sor[j-1]);
                p[ cur ].x 
= i;
                p[ cur ].y 
= sor[j];
            }

            p[ rig ].R 
= lef;

        }


        p[
0].R = 1;

        
for(i = 1; i <= m; i++{
            
int No = Num(0, i);
            
            
if(i + 1 <= m)
                p[ No ].R 
= Num(0, i+1);
            
else
                p[ No ].R 
= 0;

            p[ No ].L 
= Num(0, i-1);
            p[ No ].x 
= 0;
            p[ No ].y 
= i;
            p[ No ].Sum 
= 0;

            
int last = No;

            
for(j = 1; j <= n; j++{
                
if( map[j][i] == T ) {
                    p[ last ].Sum 
++;
                    
int now = Num(j, i);

                    p[ No ].D 
= now;
                    p[ now ].U 
= No;
                    
                    No 
= now;
                }

            }

            p[ No ].D 
= Num(0, i);
            p[ Num(
0, i) ].U = No;

            
if!p[ last ].Sum ) {
                printf(
"NO\n");
                
break;
            }

        }


        
if(i == m + 1{
            flag 
= 0;
            top 
= 0;
            dfs(
0);
            
if(!flag)
                puts(
"NO");
        }

    }

}

posted on 2009-04-04 12:14 英雄哪里出來 閱讀(2225) 評論(3)  編輯 收藏 引用 所屬分類: ACM

評論

# re: hust 1017 Exact Cover (Dancing Links)  回復  更多評論   

你這個dancing links 好陰險 .... 我怎么覺得這個很特殊呢?
希望大牛給點好的dancing links 的資料
fanxicai2000@163.com
2009-06-03 19:28 | doxi

# re: hust 1017 Exact Cover (Dancing Links)  回復  更多評論   

希望樓主多發(fā)點關于文關于dancing links
2009-09-17 10:31 | ScyNa

# re: hust 1017 Exact Cover (Dancing Links)  回復  更多評論   

表示不理解為什么通過這樣的刪減能確定是否有解呢?為什么可以這樣做?好奇怪啊。。。
2011-10-18 01:00 | 海維
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美在线播放一区二区| 亚洲女同精品视频| 欧美日韩久久| 欧美四级剧情无删版影片| 欧美日韩国语| 国产精品成人观看视频免费| 国产精品网站在线播放| 国产一二三精品| 亚洲承认在线| 亚洲视频视频在线| 久久国产天堂福利天堂| 欧美夫妇交换俱乐部在线观看| 亚洲国产精品国自产拍av秋霞| 欧美二区不卡| av不卡免费看| 久久久亚洲国产美女国产盗摄| 欧美精品日韩一本| 国产亚洲va综合人人澡精品| 亚洲国产美女精品久久久久∴| 亚洲视频在线看| 久久9热精品视频| 欧美黄网免费在线观看| 亚洲一级免费视频| 欧美xxx成人| 国产午夜精品视频| av成人激情| 久久只有精品| 亚洲一区精品电影| 欧美96在线丨欧| 国产亚洲一区二区三区在线观看 | 欧美日韩在线三区| 国产色产综合色产在线视频| 亚洲精品你懂的| 久久精品欧美日韩精品| 99re6热只有精品免费观看| 欧美在线免费一级片| 欧美吻胸吃奶大尺度电影| 91久久精品国产91性色| 欧美精品在线免费| 伊伊综合在线| 久久精品成人| 亚洲午夜国产成人av电影男同| 免费观看亚洲视频大全| 国产亚洲精品aa午夜观看| 亚洲一区中文| 99视频国产精品免费观看| 欧美www视频在线观看| 激情一区二区三区| 欧美淫片网站| 亚洲欧美在线视频观看| 欧美性事在线| av成人免费在线观看| 欧美激情按摩在线| 欧美1区2区3区| 亚洲国产欧美精品| 欧美国产专区| 欧美不卡一区| 亚洲经典一区| 亚洲激情精品| 欧美人与禽性xxxxx杂性| 亚洲精品一区二区三区av| 欧美国产乱视频| 久久综合给合久久狠狠狠97色69| 国内揄拍国内精品少妇国语| 久久婷婷久久| 乱码第一页成人| 亚洲精品影院| 一本一道久久综合狠狠老精东影业 | 国产日韩欧美综合| 欧美在线视频导航| 久久久www成人免费毛片麻豆| 黄色资源网久久资源365| 欧美不卡在线| 欧美精品在线播放| 午夜影视日本亚洲欧洲精品| 亚洲欧美日韩电影| 黑人巨大精品欧美一区二区 | 亚洲女性裸体视频| 午夜精品成人在线| 在线观看成人一级片| 亚洲国产精品电影在线观看| 欧美日韩在线播| 久久黄色小说| 欧美国产丝袜视频| 亚洲欧美清纯在线制服| 午夜精品影院| 亚洲三级免费观看| 亚洲性av在线| 91久久久久久久久| 亚洲欧美日韩成人高清在线一区| 狠狠爱成人网| 亚洲色图自拍| 尤物99国产成人精品视频| 亚洲精品一区二区三区樱花| 国产精品一区二区三区久久久| 亚洲高清视频在线观看| 亚洲黄色毛片| 国产欧美一区二区三区在线老狼| 久久久久免费观看| 欧美日韩精品三区| 久久久九九九九| 欧美日韩国产黄| 老色鬼久久亚洲一区二区| 欧美日韩在线视频观看| 欧美成人精品一区| 国产美女精品视频| 亚洲免费观看视频| 亚洲国产天堂久久综合| 亚洲欧美清纯在线制服| 亚洲视频电影图片偷拍一区| 麻豆91精品| 久久久久一区二区| 国产精品成人免费视频| 亚洲国产天堂久久综合网| 激情久久综艺| 香蕉免费一区二区三区在线观看| 夜夜嗨av一区二区三区| 久久一二三国产| 久久视频国产精品免费视频在线| 欧美性大战久久久久久久| 亚洲精品护士| 亚洲精品视频免费观看| 久久婷婷蜜乳一本欲蜜臀| 久久精品免费播放| 国产婷婷97碰碰久久人人蜜臀| 一卡二卡3卡四卡高清精品视频| 亚洲国产欧美一区| 可以免费看不卡的av网站| 久久先锋资源| 黄色在线一区| 久久人人97超碰人人澡爱香蕉 | 久久久国产精品一区| 国产九九精品视频| 亚洲综合视频一区| 欧美一区二区日韩| 国产欧美精品xxxx另类| 亚洲综合国产激情另类一区| 欧美在线|欧美| 国模一区二区三区| 久久免费国产精品| 亚洲福利国产| 中文欧美字幕免费| 国产精品男女猛烈高潮激情| 亚洲一区二区三区在线视频| 性欧美大战久久久久久久免费观看| 欧美视频在线观看免费| 亚洲网站在线播放| 久久精品夜色噜噜亚洲aⅴ| 国产一区二区在线观看免费播放| 欧美资源在线观看| 美玉足脚交一区二区三区图片| 在线观看免费视频综合| 欧美成人免费一级人片100| 亚洲精品在线电影| 欧美一级二区| 亚洲国产精品ⅴa在线观看 | 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲高清久久久| 在线一区免费观看| 国产精品日日摸夜夜添夜夜av| 亚洲欧美日韩一区二区三区在线| 久久九九精品99国产精品| 伊人久久大香线| 欧美精品在线一区二区| 亚洲中无吗在线| 欧美激情一区二区三区蜜桃视频 | 亚洲一区不卡| 美国三级日本三级久久99| 9人人澡人人爽人人精品| 国产精品日韩欧美综合| 麻豆精品一区二区av白丝在线| 亚洲伦理自拍| 免费看亚洲片| 亚洲综合大片69999| 亚洲国产精品悠悠久久琪琪| 欧美网站在线观看| 免费成人美女女| 午夜精品久久久久久久99樱桃| 亚洲国产精品一区二区第四页av| 欧美一激情一区二区三区| **欧美日韩vr在线| 国产精品久久久久久久久久久久 | 香蕉av福利精品导航| 亚洲精品日韩在线| 美女任你摸久久| 欧美一区视频在线| 亚洲色无码播放| 尤物九九久久国产精品的分类| 国产精品国产精品| 欧美看片网站| 免费观看不卡av| 欧美在线播放视频| 亚洲欧美激情四射在线日| 亚洲裸体在线观看| 欧美电影专区| 免费91麻豆精品国产自产在线观看| 午夜激情综合网| 亚洲一区视频在线| 一区二区三区偷拍| 一区二区国产日产|