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

The Fourth Dimension Space

枯葉北風(fēng)寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點)

也許你能寫出一段精致的文字,但你卻未必能寫出一段精辟的代碼。
這是我最近研究連通性問題的一個體驗,有的人的書寫了好幾頁紙,可是最終能用的卻只有1,2句話而已,我覺得在計算機的世界,沒有什么比代碼更能直接地表達(dá)出這個算法的本質(zhì)了!所以我以后要多讀代碼,少看那些空洞的文字。
言歸正傳,來看題,這是我寫的第一個強連通分量的題目,其實求強連通分量的步驟非常簡單,正反兩次使用dfs,就能得到聯(lián)通分量的一切信息。做完題目我發(fā)現(xiàn),其實求聯(lián)通分量最大的作用倒在于,聯(lián)通分量可以縮成一點,考慮為一個整體,這樣可以簡化構(gòu)圖,發(fā)掘出各個強連通分量外部之間的規(guī)律。
解題的方法就是:找出圖中所有的強連通分量并將他們縮成一點,再用外部的邊重新建圖,統(tǒng)計出新圖中出度為0的點,如果只有一個,那么說明這個強連通分量中的所有點就是題目要求的點。

題目中要特別注意:內(nèi)存池中預(yù)開的點必須是邊的三倍大小,因為構(gòu)建正圖,反圖和新圖都需要新建節(jié)點。(因為這個我wa了一次)
還有就是絕對不要使用vector,我用vector寫了一個程序,跑了600+MS,用鏈表.....47MS......10倍以上的差距,汗 - -!

#include<iostream>
using namespace std;
#define DOTMAX 10001
#define EDGEMAX 50001
struct node
{
    
int t;
    node 
*next;
}
dotset[EDGEMAX*3];

int count=0;//每一個case后,count置為0
node *Newnode()
{
    node 
*p;
    p
=&dotset[count];
    count
++;
    
return p;
}


void Addnode(node hash[],int a,int b)
{
    node 
*p=&hash[a];
    node 
*q=Newnode();
    q
->t=b;
    q
->next=p->next;
    p
->next=q;
}


node hash[DOTMAX];
node nhash[DOTMAX];
node New[DOTMAX];

int gcc;
int order[DOTMAX];
int num;
int id[DOTMAX];
int visit[DOTMAX];
int gccnum[DOTMAX];

void init(node hash[],int n)
{
    count
=0;
    
int i;
    
for(i=1;i<=n;i++)
    
{

        hash[i].t
=-1;
        hash[i].next
=NULL;
    }

}


int n,m;
void dfs(int u)
{

    visit[u]
=1;
    node 
*p;
    
int v;
    
for(p=hash[u].next;p!=NULL;p=p->next)
    
{
        v
=p->t;
        
if(!visit[v])
        
{
            dfs(v);
        }

    }

    num
++;
    order[num]
=u;
}


void ndfs(int u)
{

    visit[u]
=1;
    id[u]
=gcc;
    node 
*p;
    
int v;
    
for(p=nhash[u].next;p!=NULL;p=p->next)
    
{

        v
=p->t;
        
if(!visit[v])
        
{
            ndfs(v);
        }

    }

}



int main()
{
    
int a,b,i;
    
while(scanf("%d%d",&n,&m)!=EOF)
    
{

        init(hash,n);
        init(nhash,n);
        init(New,n);
        
for(i=1;i<=m;i++)
        
{

            scanf(
"%d%d",&a,&b);
            Addnode(hash,a,b);
            Addnode(nhash,b,a);
        }

        memset(visit,
0,sizeof(visit));
        num
=0;
        
for(i=1;i<=n;i++)
        
{
            
if(!visit[i])
                dfs(i);
        }

        memset(visit,
0,sizeof(visit));
        gcc
=0;
        
for(i=num;i>=1;i--)
        
{

            
if(!visit[order[i]])
            
{
                gcc
++;
                ndfs(order[i]);
            }

        }

        
for(i=1;i<=n;i++)
        
{
            node 
*p;
            
for(p=hash[i].next;p!=NULL;p=p->next)
            
{
                
if(id[i]!=id[p->t])
                
{

                    Addnode(New,id[i],id[p
->t]);
                }



            }

        }

        
int cnt=0;
        memset(gccnum,
0,sizeof(gccnum));
        
for(i=1;i<=n;i++)
        
{

            gccnum[id[i]]
++;
        }


        
int mark=0;
        
for(i=1;i<=gcc;i++)
        
{
            
if(New[i].next==NULL)
            
            
{
                cnt
++;
                mark
=i;
            }

        }


        
if(cnt==1)
        
{

            printf(
"%d\n",gccnum[mark]);
        }

        
else
            printf(
"%d\n",0);
    }

return 0;

}


posted on 2009-09-26 17:40 abilitytao 閱讀(2321) 評論(6)  編輯 收藏 引用

評論

# re: POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點) 2009-09-30 11:35 foxinhongyan

一點注釋都沒有,不是什么好代碼  回復(fù)  更多評論   

# re: POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點) 2009-09-30 13:55 溪流

@foxinhongyan

在追求性能的地方(如 ACM),通常不容易看到好代碼:)  回復(fù)  更多評論   

# re: POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點) 2009-09-30 18:06 abilitytao

@foxinhongyan
@溪流
在下不才 還請二位前輩多多指教  回復(fù)  更多評論   

# re: POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點) 2009-10-10 17:57 Ocean.Tu

代碼就應(yīng)該像女生的裙子  回復(fù)  更多評論   

# re: POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點) 2009-10-15 21:37 溪流

@Ocean.Tu

“像女生的裙子”是怎么樣的?  回復(fù)  更多評論   

# re: POJ 2186 Popular Cows(圖的連通性問題——有向圖的強聯(lián)通分量+縮點) 2010-03-24 13:33 Wy.Lee

@溪流
越短越好  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美人与性禽动交情品 | 亚洲一本视频| 欧美区一区二| 亚洲视频1区| 久久成人18免费观看| 国内成人精品视频| 久久人人97超碰精品888| 欧美成人一区二区| 亚洲作爱视频| 国产精品av久久久久久麻豆网| 亚洲欧美偷拍卡通变态| 快播亚洲色图| 中文久久乱码一区二区| 国产欧美二区| 欧美77777| 亚洲性感激情| 欧美高清视频一区| 午夜精品剧场| 亚洲黄色在线视频| 国产精品久久久久久av福利软件| 欧美一区观看| 亚洲精品一区二区在线观看| 亚洲欧美一区二区三区极速播放| 国内外成人在线| 欧美日韩国产一中文字不卡| 欧美影院成年免费版| 亚洲欧洲日本国产| 先锋影音网一区二区| 亚洲精品国产精品国自产观看浪潮 | 你懂的国产精品永久在线| 亚洲欧洲另类| 国产主播一区二区三区| 欧美日韩一区二区视频在线| 久久精品男女| 亚洲一区二区四区| 亚洲国产综合视频在线观看| 久久久国产一区二区| 9色精品在线| 伊人婷婷久久| 国产精品免费看片| 欧美日韩国产成人| 久久资源av| 欧美有码在线观看视频| 亚洲视频欧美在线| 亚洲欧洲在线一区| 欧美国产大片| 麻豆国产精品777777在线| 翔田千里一区二区| 亚洲一二三四久久| 亚洲乱码国产乱码精品精| 精品成人在线视频| 国产一区二区三区久久精品| 国产精品国产三级国产aⅴ浪潮 | 欧美日韩国产三区| 牛人盗摄一区二区三区视频| 久久国产精品第一页| 午夜精品福利一区二区蜜股av| 亚洲精品中文字幕在线| 欧美激情在线狂野欧美精品| 久久久久欧美| 久久亚洲春色中文字幕| 久久国产精品99国产| 亚洲欧美一区二区精品久久久| 亚洲一区二区三区乱码aⅴ| 夜夜嗨av一区二区三区中文字幕| 亚洲欧洲一区| 亚洲精品日韩久久| 亚洲人成网站在线观看播放| 亚洲激情在线| 亚洲伦伦在线| 一区二区三区 在线观看视频 | 一区二区免费看| 一本久久综合亚洲鲁鲁五月天| 亚洲精品乱码久久久久久黑人| 亚洲精品四区| 艳妇臀荡乳欲伦亚洲一区| 夜夜精品视频一区二区| 一本大道久久a久久综合婷婷| 99re8这里有精品热视频免费 | 国产一区二区三区免费不卡| 国产亚洲精品美女| 韩国女主播一区二区三区| 1000部国产精品成人观看| 亚洲激情不卡| 亚洲免费精品| 亚洲专区一二三| 欧美中文字幕| 欧美r片在线| 亚洲欧洲日韩女同| 一本色道婷婷久久欧美| 亚洲欧美国产另类| 久久久久久久一区| 欧美精品乱人伦久久久久久| 欧美天天综合网| 国产毛片一区| 亚洲黄色免费| 亚洲欧美日韩天堂一区二区| 久久久噜噜噜久久人人看| 欧美激情日韩| 亚洲天堂免费观看| 久久精品在线免费观看| 欧美激情无毛| 国产亚洲欧洲997久久综合| 亚洲第一精品夜夜躁人人爽 | 欧美激情一区二区三区不卡| 国产精品久久久久久亚洲毛片| 国产一区二区三区四区三区四| 亚洲国产另类久久精品| 亚洲一区久久久| 久久亚洲一区二区| 日韩一级黄色av| 欧美一级淫片播放口| 欧美成人情趣视频| 国产欧美精品一区aⅴ影院| 亚洲高清av在线| 亚洲欧美一区二区三区极速播放| 蜜桃av噜噜一区| 亚洲一区久久久| 欧美精品国产精品| 免费成人在线观看视频| 亚洲福利视频免费观看| 在线亚洲美日韩| 久久一区二区三区四区| 国产精品性做久久久久久| 91久久国产精品91久久性色| 亚洲欧美日韩另类| 亚洲国产午夜| 久久九九有精品国产23| 国产精品成人v| 亚洲精品日日夜夜| 久久综合色婷婷| 亚洲免费综合| 欧美视频在线视频| 亚洲国产婷婷| 久久青青草综合| 亚洲你懂的在线视频| 欧美日本国产一区| 亚洲国产精品一区在线观看不卡 | 亚洲欧美日韩在线不卡| 亚洲激情第一页| 久久夜色精品| 国产一区亚洲| 久久精品视频导航| 亚洲婷婷综合色高清在线| 欧美日韩久久久久久| 亚洲美女免费精品视频在线观看| 美女网站久久| 欧美在线观看一二区| 国产精品亚发布| 亚洲一区免费| 亚洲少妇最新在线视频| 欧美日韩高清免费| 99精品国产一区二区青青牛奶 | 欧美日韩亚洲一区二区三区在线| 亚洲国产视频直播| 奶水喷射视频一区| 久久精品国产清高在天天线| 国产亚洲一区二区在线观看| 小黄鸭精品密入口导航| 在线视频日本亚洲性| 国产精品成av人在线视午夜片| 中文av一区特黄| 一本色道久久综合亚洲精品按摩 | 国内精品久久久久伊人av| 亚洲欧美日韩精品| 亚洲综合色婷婷| 国产欧美一区二区三区视频| 久久精品2019中文字幕| 欧美一区二区大片| 国内外成人在线| 欧美+日本+国产+在线a∨观看| 久久综合久久久| 亚洲人体一区| 亚洲美女网站| 国产精品国色综合久久| 午夜精品亚洲| 久久久久久久91| 日韩午夜在线视频| 一本色道久久| 国产亚洲午夜高清国产拍精品| 久久亚洲国产精品日日av夜夜| 久久久亚洲高清| 亚洲精品三级| 亚洲一级高清| 激情视频一区二区| 亚洲欧洲中文日韩久久av乱码| 欧美日韩免费| 久久久999国产| 欧美不卡视频| 亚洲视频图片小说| 欧美亚洲三区| 亚洲精品视频一区| 亚洲综合欧美| 在线看视频不卡| 99伊人成综合| 国产在线麻豆精品观看| 亚洲第一精品福利| 国产精品久久久久久久久久ktv| 久久国产精品毛片| 免费不卡在线视频|