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

隨筆 - 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 英雄哪里出來 閱讀(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>
            亚洲一区二区三区色| 樱桃视频在线观看一区| 久久久精品动漫| 欧美久久电影| 亚洲电影一级黄| 久久久久国产精品厨房| 在线视频亚洲一区| 暖暖成人免费视频| 免费欧美电影| 一区二区三区在线免费播放| 亚洲一区二区在线播放| 久久se精品一区精品二区| 国产精品久久久久久久久久免费 | 亚洲国产成人精品久久久国产成人一区 | 亚洲三级网站| 午夜久久久久| 久久av一区二区三区漫画| 激情伊人五月天久久综合| 欧美激情视频给我| 亚洲日本aⅴ片在线观看香蕉| 亚洲国产高清aⅴ视频| 久久久青草青青国产亚洲免观| 亚洲国产精品国自产拍av秋霞| 亚洲大胆av| 久久青青草综合| 你懂的视频欧美| 亚洲精品美女| 国产三区二区一区久久| 欧美一级视频免费在线观看| 久久久久中文| 亚洲国产三级在线| 欧美激情精品久久久久久大尺度| 亚洲经典视频在线观看| 一本综合精品| 国产精品嫩草久久久久| 久久婷婷国产麻豆91天堂| 一区二区国产日产| 久久激情视频免费观看| 国产主播精品在线| 美女视频黄免费的久久| 亚洲国产一区二区三区青草影视| 欧美一区二区三区四区高清| 狠狠色噜噜狠狠色综合久| 美女视频黄a大片欧美| 午夜精品久久久| 玖玖玖免费嫩草在线影院一区| 在线成人亚洲| 国产人妖伪娘一区91| 久久久久久久综合日本| 亚洲免费视频一区二区| 美女主播视频一区| 久久九九热re6这里有精品| 亚洲一二三级电影| 韩日精品在线| 国产日韩欧美在线播放不卡| 国产精品伦一区| 欧美日韩亚洲网| 欧美一区亚洲| 亚洲精品视频在线播放| 欧美在线观看视频一区二区三区| 在线亚洲观看| 在线视频你懂得一区| 亚洲美女中出| 国户精品久久久久久久久久久不卡| 国产精品久久77777| 欧美日韩在线观看一区二区三区| 欧美激情国产日韩精品一区18| 浪潮色综合久久天堂| 在线亚洲伦理| 欧美黄色一级视频| 欧美在线1区| 先锋影音国产一区| 日韩亚洲欧美成人一区| 国产综合精品| 黄色亚洲大片免费在线观看| 国产综合久久久久久| 国产主播一区二区三区四区| 性欧美大战久久久久久久免费观看| 欧美黄色免费| 亚洲欧洲日本专区| 亚洲精选中文字幕| 日韩亚洲欧美一区二区三区| 久久久不卡网国产精品一区| 久久经典综合| 免费亚洲电影在线| 亚洲国产精品黑人久久久| 91久久中文| 正在播放欧美视频| 午夜影院日韩| 老牛嫩草一区二区三区日本| 欧美成人免费全部| 久久久人成影片一区二区三区| 久久综合亚洲社区| 欧美国产激情| 国产精品老牛| 亚洲第一精品夜夜躁人人躁 | 亚洲精品在线观| 亚洲深夜福利网站| 午夜久久影院| 欧美chengren| 国产精品久久国产精品99gif| 国产一区二区福利| 国产伦精品一区二区三区照片91| 欧美视频在线免费看| 欧美日韩成人在线| 欧美激情中文不卡| 国产精品女人网站| 亚洲国产成人精品久久久国产成人一区 | 亚洲国产精品成人精品| 亚洲图片在线观看| 一区二区三区高清| 久久精品官网| 91久久香蕉国产日韩欧美9色| 亚洲校园激情| 亚洲欧美日韩在线高清直播| 久久久亚洲成人| 国产精品久久999| 亚洲国产裸拍裸体视频在线观看乱了中文| 中文av字幕一区| 美女主播精品视频一二三四| 中国亚洲黄色| 欧美国产精品va在线观看| 国产日韩av一区二区| 99国产精品久久久久老师| 久久婷婷国产综合精品青草| 女生裸体视频一区二区三区| 亚洲少妇一区| 欧美极品一区| 永久91嫩草亚洲精品人人| 香蕉久久夜色精品国产| 亚洲欧洲一区| 毛片基地黄久久久久久天堂| 国产视频一区二区在线观看| 一本久道久久综合婷婷鲸鱼| 欧美成人免费全部| 亚洲经典三级| 久久久午夜视频| 国产亚洲欧美aaaa| 欧美亚洲自偷自偷| 99国产精品久久久久久久成人热| 亚洲一区久久久| 欧美日韩一二三区| 亚洲精品久久嫩草网站秘色| 另类天堂视频在线观看| 欧美一区2区三区4区公司二百| 欧美人与禽猛交乱配视频| 亚洲欧洲午夜| 欧美中文字幕| 亚洲永久精品大片| 国产精品三上| 亚洲人成亚洲人成在线观看| 久久精品视频导航| 亚洲欧美日韩电影| 国产精品一区二区在线观看| 在线亚洲欧美视频| 99re6热只有精品免费观看| 欧美激情在线免费观看| 日韩视频一区二区在线观看| 亚洲高清网站| 欧美女主播在线| 一区二区欧美日韩| 一本久久综合亚洲鲁鲁| 欧美三级欧美一级| 亚洲一区二区视频在线观看| 欧美中文字幕视频| 亚洲欧美日韩国产中文在线| 国产精品系列在线| 欧美在线视屏| 久久爱91午夜羞羞| 国产精品国产三级国产aⅴ9色| 亚洲五月六月| 亚洲欧美经典视频| 国产综合在线看| 欧美国产精品一区| 欧美精品福利在线| 亚洲午夜电影在线观看| 亚洲欧美日韩国产精品| 国产在线播放一区二区三区| 久久综合伊人77777蜜臀| 老司机免费视频一区二区| 亚洲精品久久久久久下一站 | 亚洲国产精品成人va在线观看| 欧美国产日韩精品| 欧美日韩国产一区二区| 午夜亚洲性色视频| 久久精品久久综合| 国产一区二区三区av电影| 快播亚洲色图| 欧美黄色免费网站| 欧美一级大片在线观看| 久久男人资源视频| 一区二区三区www| 亚洲一区二区免费| 在线高清一区| 99视频精品全部免费在线| 国产一区二区电影在线观看| 亚洲第一搞黄网站| 国产精品入口麻豆原神| 欧美粗暴jizz性欧美20| 国产精品久久久久77777|