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

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

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] 保存當前結(jié)點訪問情況                                                                     *
* int father[i] 保存i的父親結(jié)點的編號                                                                 *
* 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 英雄哪里出來 閱讀(705) 評論(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>
            久久亚洲高清| 一本大道久久a久久综合婷婷| 欧美91精品| 亚洲字幕一区二区| 亚洲丶国产丶欧美一区二区三区 | 99re成人精品视频| 欧美aa在线视频| 欧美一级理论片| 中文有码久久| 亚洲人成在线观看| 一区二区在线观看av| 国产日韩欧美在线播放| 欧美日韩精品一区| 欧美国产精品va在线观看| 久久久精品一区二区三区| 午夜精品久久久久久久久久久久久 | av成人国产| 亚洲国产福利在线| 欧美a级大片| 久久综合色婷婷| 久久精品噜噜噜成人av农村| 香蕉久久精品日日躁夜夜躁| 一区二区三区精品视频| 亚洲精品永久免费| 亚洲国产精品免费| 亚洲高清视频在线| 在线播放亚洲| 1769国产精品| 伊人蜜桃色噜噜激情综合| 国内成人精品视频| 国产一区二区三区四区老人| 国产欧美69| 国产情人节一区| 国产婷婷成人久久av免费高清 | 亚洲综合色激情五月| 亚洲五月婷婷| 亚洲影院在线观看| 亚洲欧美成人| 性久久久久久| 欧美在线日韩在线| 久久久91精品国产一区二区精品| 久久国产精品久久久久久电车 | 久久久精品午夜少妇| 久久精品久久综合| 久久综合免费视频影院| 免费久久久一本精品久久区| 免费国产一区二区| 欧美乱在线观看| 欧美先锋影音| 国产日韩欧美中文在线播放| 国产一区二区三区在线观看免费视频| 国产偷国产偷亚洲高清97cao| 国产午夜精品在线| 亚洲第一视频网站| 99精品国产一区二区青青牛奶| 亚洲视频在线视频| 欧美一区综合| 麻豆国产精品va在线观看不卡 | 性做久久久久久久久| 久久国产黑丝| 女女同性女同一区二区三区91| 欧美成人性生活| 国产精品va在线播放我和闺蜜| 国产精品视频最多的网站| 国产午夜一区二区三区| 亚洲国产高清视频| 亚洲免费一级电影| 久久久久综合网| 亚洲韩日在线| 亚洲一区综合| 久久久亚洲国产美女国产盗摄| 欧美极品影院| 国产伦精品一区二区三区照片91| 国内免费精品永久在线视频| 日韩视频精品在线观看| 性做久久久久久久免费看| 免费不卡亚洲欧美| 一本一道久久综合狠狠老精东影业 | 久久久久国产一区二区| 亚洲第一中文字幕| 亚洲影院免费观看| 欧美1区2区3区| 国产精品综合不卡av| 亚洲国产日韩欧美在线图片| 亚洲一区二区日本| 欧美电影打屁股sp| 亚洲欧美激情视频| 欧美激情综合五月色丁香小说| 国产精品综合久久久| 日韩午夜电影| 久久一区二区三区超碰国产精品| 亚洲伦理在线免费看| 久久精品国语| 国产精品毛片va一区二区三区| 亚洲国语精品自产拍在线观看| 午夜精品久久久久久久99水蜜桃 | 在线视频亚洲| 老司机午夜精品| 国产欧美丝祙| 亚洲视频福利| 亚洲福利视频二区| 久久激情网站| 国产美女精品免费电影| 日韩一级二级三级| 欧美福利视频网站| 欧美一区二视频在线免费观看| 欧美色视频在线| 亚洲精选国产| 欧美国产激情二区三区| 久久国产免费看| 国产精品区二区三区日本| av成人免费观看| 欧美成人一区二区三区片免费| 亚洲欧美日韩在线一区| 欧美天天综合网| 一本色道综合亚洲| 亚洲国产成人精品久久久国产成人一区| 欧美在线精品免播放器视频| 国产精品久久久久av免费| 夜夜精品视频| 亚洲精品视频免费在线观看| 欧美夫妇交换俱乐部在线观看| 亚洲国产精品久久精品怡红院| 久久人人九九| 久久精品视频在线观看| 国产最新精品精品你懂的| 久久激情五月激情| 欧美亚洲综合在线| 国产夜色精品一区二区av| 欧美在线观看一区二区三区| 亚洲欧美日韩国产一区二区三区| 国产精品久久999| 亚洲欧美一区二区三区久久| 亚洲小视频在线| 国产精品美腿一区在线看| 欧美亚洲在线播放| 亚洲欧美日韩综合aⅴ视频| 国产女精品视频网站免费| 欧美中文在线观看| 久久精品欧美日韩| 亚洲成在人线av| 欧美肥婆bbw| 欧美巨乳在线| 亚洲一区欧美激情| 午夜一区二区三区不卡视频| 国内精品久久久久伊人av| 美女成人午夜| 欧美激情在线观看| 亚洲视频专区在线| 亚洲一区二区三区精品视频| 国产一区二区欧美| 嫩草影视亚洲| 欧美精品系列| 亚洲欧美一级二级三级| 久久精品国产999大香线蕉| 亚洲电影免费在线| 日韩一本二本av| 国产精品日韩精品| 噜噜噜躁狠狠躁狠狠精品视频 | 久久久久国产一区二区| 久久精品一区四区| 在线视频成人| 亚洲大胆人体在线| 欧美日韩一区二区三区高清| 亚洲图片欧洲图片日韩av| 一卡二卡3卡四卡高清精品视频| 国产伦精品一区二区三区四区免费 | 欧美黄色小视频| 欧美成人免费在线观看| 亚洲欧美国产日韩天堂区| 欧美一区二区精美| 极品尤物av久久免费看| 亚洲蜜桃精久久久久久久| 国产精品免费看| 欧美综合国产| 久久影院亚洲| 午夜精品久久久久久久久| 久久国产精品99久久久久久老狼| 亚洲福利av| 亚洲日本aⅴ片在线观看香蕉| 国产精品无码永久免费888| 久久久国产精品一区二区三区| 蜜臀av在线播放一区二区三区| 亚洲欧美日韩精品| 久久久噜噜噜久久人人看| 日韩网站在线观看| 在线视频日韩| 亚洲美女黄网| 亚洲男人天堂2024| 亚洲国产成人精品久久| 亚洲一区在线播放| 亚洲国产专区校园欧美| 一本在线高清不卡dvd| 国产在线乱码一区二区三区| 99re6热在线精品视频播放速度| 国产午夜精品理论片a级探花| 亚洲高清一区二区三区| 国产亚洲一区精品| 亚洲精品系列| 狠狠色综合网站久久久久久久|