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

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

Pku 3140 Contestants Division (無向圖割邊+樹形DP)

由于該圖不是一顆樹,所以首先要將一些塊壓縮成點,所謂塊就是沒有割點的分量,于是只要求出割邊,然后刪除,之后對整個圖進行Floodfill,得到的連通分量再用割邊
補圖,得到的圖一定是一棵樹,然后就可以樹形DP了。
#include <iostream>
#define MAXN 100010
using namespace std;

struct list {
    list 
*next;
    
int ID;
}
;

int n, m;
int value[ MAXN ];

list data[ 
1000000 ];
list 
*vec[ MAXN ];
list 
*Bri[ MAXN ];
int Ance[ MAXN ];
int Dep[ MAXN ];
int Color[ MAXN ];
int father[ MAXN ];
bool Cut[ MAXN ];
int num[ MAXN ];
#define G 0  // Grey    正在訪問
#define B 1  // Black   訪問完畢
#define W 2  // White   未曾訪問
int root, T;

/*******************求無向圖割邊割點********************
* list vec[i] 表示原的鄰接表                                                                                       * 
* list Bri[i] 保存割邊                                                                                                      *
* bool Cut[i] 保存割點                                                                                                    *
* int Ance[i] 保存和i或i的子孫鄰接的最高輩分的祖先的深度                            *
* int Dep[i] 保存i點所在的深度                                                                                  *
* int Color[i] 保存當前結點訪問情況                                                                     *
* int father[i] 保存i的父親結點的編號                                                                 *
* int num[i] 縮點后每個點所在的新塊的編號                                                  *
********************************************************
*/


int Min ( int a, int b ) {
    
return a < b ? a : b;
}


void BridgeCut( int key, int depth ) {

    
int son = 0;
    Dep[ key ] 
= depth;
    Color[ key ] 
= G;
    Ance[ key ] 
= depth;

    list 
*p, *q;

    
for( p = vec[ key ]->next; p ; p = p->next ) {

        
int next = p->ID;

        
if( next != father[ key ] && Color[ next ] == G) {
            Ance[ key ] 
= Min( Ance[ key ], Dep[ next ] );
        }


        
if( Color[ next ] == W ) {

            father[ next ] 
= key;
            BridgeCut( next, depth 
+ 1);
            son 
++; Ance[ key ] = Min( Ance[ key ], Ance[ next ] );
            
// 判割點
            if( key == root ) {
                
if( son > 1 ) {
                    Cut[ key ] 
= true;
                }

            }
else {
                
if( Ance[ next ] >= Dep[ key ] ) {
                    Cut[ key ] 
= true;
                }

            }


            
// 判割邊
            if( Ance[ next ] > Dep[ key ] ) {
                q 
= &data[ T++ ];
                q
->ID = next;
                q
->next = Bri[ key ]->next;
                Bri[ key ]
->next = q;
                
                q 
= &data[ T++ ];
                q
->ID = key;
                q
->next = Bri[ next ]->next;
                Bri[ next ]
->next = q;
            }

        }

    }


    Color[ key ] 
= B;
}



void CreateGraph() {

    
int i, x, y;
    T 
= 0;

    
for(i = 1; i <= n; i++)
        scanf(
"%d"&value[i]);
    
for(i = 1; i <= n; i++{

        Bri[i] 
= &data[ T++ ];
        Bri[i]
->ID = i;
        Bri[i]
->next = NULL;

        vec[i] 
= &data[ T++ ];
        vec[i]
->ID = i;
        vec[i]
->next = NULL;

        Ance[i] 
= INT_MAX;

        Cut[i] 
= false;
        Color[ i ] 
= W;
    }


    list 
*p;
    
while( m-- ) {
        scanf(
"%d %d"&x, &y);

        p 
= &data[ T++ ];
        p
->next = vec[x]->next;
        p
->ID = y;
        vec[x]
->next = p;

        p 
= &data[ T++ ];
        p
->next = vec[y]->next;
        p
->ID = x;
        vec[y]
->next = p;
    }

}


/*
割邊割點輸出,以及縮塊后的圖的鄰接表
*/


void Print() {
    list 
*p;
    
int i;
    
for(i = 1; i <= n; i++{
        printf(
"%d: ", i);
        
for(p = Bri[i]->next; p; p = p->next) {
            printf(
"%d ", p->ID);
        }

        puts(
"");
    }

    
for(i = 1; i <= n; i++{
        
if( Cut[i] )
            printf(
"point : %d\n", i);
    }

}




/*以下是樹形DP的過程*/


bool IsBridge(int u, int v) {
    list 
*p;
    
for( p = Bri[u]->next; p ; p = p->next ) {
        
if( p->ID == v )
            
return 1;
    }

    
return 0;
}


int F;

// 分塊 
void dfs( int key ) {
    list 
*p;
    num[ key ] 
= F;
    
for(p = vec[ key ]->next; p ; p = p->next ) {
        
if( Color[ p->ID ] == W  && !IsBridge(key, p->ID) ) {
            Color[ p
->ID ] = B;
            dfs( p
->ID );
        }

    }

}




void FloodFill() {
    
int i;
    
for(i = 1; i <= n; i++)
        Color[i] 
= W;
    F 
= 1;
    
for(i = 1; i <= n; i++{
        
if( Color[i] == W ) {
            Color[i] 
= B;
            dfs(i);
            F 
++;
        }

    }

}


__int64 AllVal[ MAXN ];
__int64 M, zong;
list 
*New[ MAXN ];
int hash[ MAXN ];


// TreeDp
void Search( int key ) {
    list 
*p;
    
int son = 0;

    
for( p = New[ key ]->next; p; p = p->next) {
        
        
int q = p->ID;
        
if( hash[ q ] )
            
continue;
        son 
++;
        hash[ q ] 
= 1;
        Search(q);
        AllVal[ key ] 
+= (__int64)AllVal[ q ];
        __int64 a 
= zong - AllVal[ q ];
        __int64 b 
= AllVal[ q ];
        a 
-= b;
        
if( a < 0)
            a 
= -a;
        
if( a < M )
            M 
= a;
    }
    
}



void TreeDp() {

    
int i;
    M 
= 0;
    memset( AllVal, 
0sizeof(AllVal) );
    
for(i = 1; i <= n; i++{
        AllVal[ num[i] ] 
+= (__int64)value[i];
        M 
+= (__int64)value[i];
    }

    zong 
= M;
    F 
--;
    
for(i = 1; i <= F; i++{
        New[i] 
= &data[ T++ ];
        New[i]
->ID = i;
        New[i]
->next = NULL;
    }


    list 
*p, *q;

    
for(i = 1; i <= n; i++{
        
for(p = Bri[i]->next; p; p = p->next) {
            q 
= &data[ T++ ];
            q
->ID = num[ p->ID ];
            q
->next = New[ num[i] ]->next;
            New[ num[i] ]
->next = q;
        }

    }


    memset( hash, 
0sizeof(hash) );
    hash[
1= 1;
    Search(
1);
}


int main() {

    
int i;
    
int t = 1;

    
while( scanf("%d %d"&n, &m) != EOF && (n || m) ) {
        CreateGraph();
        root 
= 1;
        father[ root ] 
= 0;
        BridgeCut( root, 
0 );
        FloodFill();
        
//Print();
        TreeDp();
        printf(
"Case %d: %I64d\n", t++, M);
    }

    
return 0;
}

posted on 2009-05-07 13:35 英雄哪里出來 閱讀(701) 評論(1)  編輯 收藏 引用 所屬分類: ACM

評論

# re: Pku 3140 Contestants Division (無向圖割邊+樹形DP)  回復  更多評論   

大牛,orz一下。
2010-03-29 18: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>
            亚洲激情综合| 欧美四级在线| 久久免费视频一区| 亚洲一区二区三区777| 日韩一本二本av| 一本久久综合| 亚洲一区二区在线观看视频| 亚洲美女av在线播放| 亚洲日本乱码在线观看| 亚洲精品色图| 亚洲欧美成人在线| 久久午夜精品| 亚洲片在线观看| 亚洲乱码国产乱码精品精| 99国产精品久久久久久久成人热| 一二美女精品欧洲| 亚洲一区视频在线| 美女国产一区| 国产精品国产三级国产普通话99 | 久久国产精品久久w女人spa| 久久综合伊人77777蜜臀| 欧美乱大交xxxxx| 国产精品―色哟哟| 在线精品国产欧美| 亚洲深夜福利视频| 欧美99在线视频观看| 中文欧美字幕免费| 久热精品视频在线观看| 欧美四级在线观看| 亚洲电影在线| 亚洲无限av看| 欧美黄色大片网站| 午夜一区二区三视频在线观看| 欧美14一18处毛片| 国产精品一区二区在线| 亚洲精品在线二区| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲人体偷拍| 久久精品人人做人人爽| 亚洲精品在线免费| 久久影院亚洲| 国产日产欧产精品推荐色| 亚洲美女电影在线| 欧美大学生性色视频| 亚洲欧洲av一区二区| 亚洲福利在线视频| 欧美尤物一区| 国产精品国产自产拍高清av| 亚洲国产一区二区精品专区| 香蕉久久a毛片| 一区二区三区福利| 欧美日韩一区综合| 999亚洲国产精| 亚洲国产精品va在看黑人| 久久中文字幕导航| 一区二区三区亚洲| 久久亚洲春色中文字幕| 欧美一区二区三区视频| 国产亚洲精品久| 久久久精品国产免费观看同学| 性欧美xxxx大乳国产app| 国产欧美日韩精品专区| 性久久久久久久久久久久| 99这里只有久久精品视频| 欧美日韩国产区一| 亚洲综合色在线| 亚洲色图综合久久| 国产嫩草一区二区三区在线观看| 亚洲欧美亚洲| 亚洲欧美国产毛片在线| 国产精品系列在线| 久久久91精品国产| 久久爱www久久做| 伊人久久久大香线蕉综合直播| 免费久久99精品国产自| 免费成人黄色| 国产精品99久久久久久久久| 在线中文字幕一区| 国产午夜亚洲精品羞羞网站| 久久只精品国产| 欧美黑人国产人伦爽爽爽| 一区二区三区久久精品| 亚洲一区在线看| 在线观看成人一级片| 91久久精品国产91性色tv| 欧美日韩精品久久| 久久国产精品久久久| 蜜桃伊人久久| 性色av一区二区三区在线观看| 午夜精品久久久久久久| 亚洲人成人99网站| 亚洲午夜av在线| 亚洲二区在线视频| 亚洲色图在线视频| 亚洲高清123| 在线中文字幕一区| 在线观看欧美一区| 亚洲婷婷在线| 亚洲国产一区二区三区高清| 日韩视频一区二区| 国产一区二区av| 亚洲清纯自拍| 狠狠做深爱婷婷久久综合一区 | 亚洲视频视频在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲欧洲一区二区在线播放| 一区二区三区 在线观看视频| 韩国在线视频一区| 一本久道久久综合狠狠爱| 国内精品一区二区| 一本到12不卡视频在线dvd | 亚洲自拍16p| 美女主播一区| 久久精品成人| 欧美午夜片在线观看| 亚洲东热激情| 久久久久久亚洲综合影院红桃| 欧美日韩国产一级片| 欧美福利视频在线| 国产亚洲一二三区| 亚洲一区二区三区四区在线观看| 亚洲精品国产精品国自产在线| 亚洲欧美日韩国产综合| 亚洲视频精选| 欧美激情国产日韩| 免费观看一级特黄欧美大片| 国产亚洲一区二区在线观看 | 久久久www| 久久爱www久久做| 欧美日韩国内自拍| 91久久久久久久久久久久久| 亚洲国产激情| 久久综合电影| 久久综合影音| 黄网站免费久久| 久久久精品久久久久| 久久免费精品视频| 黄色成人免费观看| 久久精品国产2020观看福利| 欧美与黑人午夜性猛交久久久| 国产精品二区影院| 亚洲综合999| 久久精品国产综合精品| 国产目拍亚洲精品99久久精品| 亚洲欧美日本在线| 欧美在线一二三| 国产最新精品精品你懂的| 欧美一区二区免费观在线| 久久亚洲精品一区二区| 1024亚洲| 欧美女激情福利| 亚洲一区二区三区午夜| 久久九九久精品国产免费直播| 在线成人h网| 欧美黑人多人双交| 亚洲美女色禁图| 久久xxxx| 亚洲精品日韩激情在线电影| 欧美体内谢she精2性欧美| 亚洲欧美中文字幕| 欧美大秀在线观看| 亚洲自啪免费| 一区视频在线播放| 欧美精品日韩三级| 亚洲影视在线播放| 美女网站久久| 亚洲一区欧美二区| 国产综合色精品一区二区三区| 免费人成网站在线观看欧美高清 | 久久精品国产99精品国产亚洲性色 | 国产专区欧美精品| 美日韩精品视频| 一区二区三区产品免费精品久久75| 欧美一二三区在线观看| 在线看欧美日韩| 欧美日韩一级视频| 先锋影音国产精品| 亚洲精品网站在线播放gif| 久久国产精品一区二区三区| 亚洲精品午夜精品| 国产日韩在线不卡| 欧美日本免费| 久久网站热最新地址| 一区二区欧美激情| 欧美sm极限捆绑bd| 久久福利毛片| 亚洲桃色在线一区| 亚洲第一区中文99精品| 国产精品久久久久久久久搜平片 | 亚洲欧洲99久久| 亚洲免费福利视频| 老**午夜毛片一区二区三区| 午夜精品国产更新| 99在线精品观看| 亚洲国产欧美另类丝袜| 国产亚洲一级| 国产欧美一区视频| 欧美日韩天堂| 欧美成ee人免费视频| 久久午夜色播影院免费高清|