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

隨筆 - 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>
            精品动漫3d一区二区三区| 99v久久综合狠狠综合久久| 亚洲视频在线观看视频| 久久精品一区二区国产| 欧美一区二区啪啪| 国产精品久久久久久一区二区三区 | 久久狠狠婷婷| 性色av一区二区三区| 欧美三级日本三级少妇99| 最新亚洲视频| 伊人久久综合97精品| 午夜性色一区二区三区免费视频| 亚洲在线播放| 激情久久久久久久| 欧美日韩一区二区免费在线观看| 亚洲无限av看| 免费成人小视频| 亚洲午夜国产成人av电影男同| 国产精品久久久一本精品| 一区二区三区视频观看| 久久久人成影片一区二区三区观看| 亚洲国产精品成人一区二区| 欧美日韩视频在线| 久久久久久久97| 亚洲精品国偷自产在线99热| 午夜精品久久久久影视| 亚洲第一天堂无码专区| 欧美精品一区二区三区高清aⅴ| 亚洲国产色一区| 久久亚洲捆绑美女| 亚洲一区二区三区高清不卡| 国产一区二区三区免费在线观看| 蜜臀a∨国产成人精品| 亚洲精品在线一区二区| 精品福利电影| 国产视频综合在线| 国产精品久久久久久久久借妻 | 亚洲精品在线观看免费| 久久久在线视频| 久久国产精品网站| 亚洲一区3d动漫同人无遮挡| 亚洲精品视频在线观看网站| 亚洲黄色免费电影| 亚洲国产黄色| 亚洲精品一区二区网址| 亚洲黄色小视频| 中文精品视频一区二区在线观看| 亚洲人成在线观看网站高清| 亚洲激情av| 亚洲日本精品国产第一区| 91久久午夜| 亚洲美女黄网| 亚洲一区二区黄色| 久久激情网站| 欧美高清视频www夜色资源网| 欧美一区二视频| 久久深夜福利免费观看| 亚洲成色777777女色窝| 亚洲精品国产精品久久清纯直播| 日韩视频免费在线观看| 在线综合+亚洲+欧美中文字幕| 99一区二区| 久久av一区二区三区| 欧美激情中文字幕乱码免费| 国产精品拍天天在线| 在线精品视频免费观看| 亚洲深夜福利在线| 免费成人高清| 亚洲午夜久久久久久久久电影院| 欧美高清自拍一区| 欧美激情视频在线播放| 亚洲网站视频| 免费中文字幕日韩欧美| 国产亚洲一区在线播放| 在线综合亚洲| 欧美国产激情二区三区| 久久狠狠一本精品综合网| 久久青青草原一区二区| 一区二区欧美日韩视频| 欧美精品久久99| 亚洲人久久久| 欧美黄色日本| 免费短视频成人日韩| 一区视频在线播放| 久久亚洲综合色| 欧美在线一二三区| 国产日本欧美一区二区三区| 亚洲免费在线视频一区 二区| 亚洲另类自拍| 国产精品视频一二三| 亚洲一区在线免费观看| 一区二区精品国产| 国产精品久久国产愉拍| 亚洲综合欧美| 午夜精品视频网站| 亚洲人精品午夜在线观看| 亚洲乱码国产乱码精品精可以看 | 亚洲香蕉视频| 亚洲无亚洲人成网站77777| 欧美午夜片欧美片在线观看| 亚洲性视频网址| 欧美一区二区日韩一区二区| 国内自拍视频一区二区三区 | 亚洲欧美久久| 好看的日韩视频| 亚洲日本中文字幕| 国产一区二区三区久久久久久久久| 老色鬼精品视频在线观看播放| 欧美高清视频一区二区| 国产日韩精品在线| 美女爽到呻吟久久久久| 欧美精品在欧美一区二区少妇| 亚洲视频一区在线| 久久精品欧美| 久久成人免费电影| 欧美日韩1区2区| 美女视频一区免费观看| 国产精品热久久久久夜色精品三区| 麻豆成人在线| 国产视频欧美视频| 亚洲欧美日韩在线播放| 99xxxx成人网| 欧美成人激情在线| 欧美国产一区二区| 国产一区91| 新67194成人永久网站| 午夜精彩国产免费不卡不顿大片| 欧美 日韩 国产精品免费观看| 久久久久国产精品厨房| 国产精品久久久一本精品| 亚洲日本va午夜在线影院| 亚洲日本无吗高清不卡| 美日韩精品视频免费看| 欧美成人精品高清在线播放| 黑人操亚洲美女惩罚| 久久久久9999亚洲精品| 欧美成人免费在线| 日韩视频在线一区二区| 欧美日韩一级大片网址| 亚洲婷婷综合色高清在线| 亚洲一区三区在线观看| 国产精品亚洲欧美| 久久麻豆一区二区| 日韩视频一区二区在线观看 | 蜜臀av国产精品久久久久| 一区二区视频免费完整版观看| 久久综合久久88| 亚洲激情在线| 久久成人免费电影| 99视频国产精品免费观看| 国产精品国产a级| 久久精品一区二区三区不卡牛牛| 亚洲人屁股眼子交8| 亚洲一区区二区| 最新高清无码专区| 国产一区视频在线观看免费| 欧美日韩不卡| 亚洲国产日韩一区| 亚洲欧美国产毛片在线| 91久久综合| 国产亚洲aⅴaaaaaa毛片| 欧美大片专区| 久久婷婷人人澡人人喊人人爽| 欧美一区91| 亚洲线精品一区二区三区八戒| 狠狠做深爱婷婷久久综合一区| 欧美色欧美亚洲另类二区| 欧美成人免费观看| 翔田千里一区二区| 亚洲欧美制服另类日韩| 亚洲图片你懂的| 亚洲免费在线观看视频| 亚洲一区二区欧美日韩| 亚洲一区二区欧美| 西西裸体人体做爰大胆久久久| 一区二区三区 在线观看视| 亚洲毛片av| 亚洲午夜精品在线| 亚洲欧美网站| 久久夜色精品亚洲噜噜国产mv | 亚洲国产免费| 亚洲伦伦在线| 亚洲在线视频网站| 久久国产视频网站| 欧美1区2区视频| 欧美激情一区二区三区不卡| 欧美xart系列高清| 欧美视频免费在线观看| 国产日韩欧美日韩| 亚洲第一区在线观看| avtt综合网| 蜜桃av综合| 一本色道久久综合精品竹菊| 西瓜成人精品人成网站| 久久夜色精品国产亚洲aⅴ| 欧美va天堂| 国产日韩欧美亚洲| 亚洲精品一区二区三区av| 欧美一区二区三区喷汁尤物| 欧美成人首页|