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

The Fourth Dimension Space

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

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

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

題目中要特別注意:內(nèi)存池中預(yù)開(kāi)的點(diǎn)必須是邊的三倍大小,因?yàn)闃?gòu)建正圖,反圖和新圖都需要新建節(jié)點(diǎn)。(因?yàn)檫@個(gè)我wa了一次)
還有就是絕對(duì)不要使用vector,我用vector寫(xiě)了一個(gè)程序,跑了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;//每一個(gè)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 閱讀(2314) 評(píng)論(6)  編輯 收藏 引用

評(píng)論

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

一點(diǎn)注釋都沒(méi)有,不是什么好代碼  回復(fù)  更多評(píng)論   

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

@foxinhongyan

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

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

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

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

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

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

@Ocean.Tu

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

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

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


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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>
            麻豆freexxxx性91精品| 91久久久亚洲精品| 午夜精品影院在线观看| 欧美日韩一区二区三区免费| 99成人在线| 亚洲美女免费视频| 亚洲一区二区视频| 亚洲欧洲av一区二区| 先锋影院在线亚洲| 久久激情视频| 免费日韩av电影| 久久资源av| 欧美精品一区二区三区视频| 亚洲一区二区在线看| 亚洲欧美日韩国产一区二区三区| 中国成人亚色综合网站| 性欧美暴力猛交另类hd| 美女免费视频一区| 国产精品免费一区二区三区在线观看| 欧美日精品一区视频| 国产精品美女诱惑| 在线国产日韩| 亚洲欧美日韩在线高清直播| 欧美在线观看视频一区二区| 美女精品自拍一二三四| 亚洲经典三级| 亚洲自拍三区| 欧美精品一区二区三区蜜桃| 欧美日韩伦理在线免费| 狠狠久久综合婷婷不卡| 亚洲综合色视频| 亚洲国产片色| 欧美极品一区二区三区| 国内精品久久久久久久影视蜜臀 | 国产精品久久久久久久久免费| 亚洲国产高清一区二区三区| 亚洲男人的天堂在线观看| 欧美激情视频一区二区三区不卡| 国产在线播精品第三| 亚洲欧美日韩精品久久亚洲区| 亚洲电影免费在线观看| 免费人成精品欧美精品| 在线观看欧美日韩| 久久五月婷婷丁香社区| 欧美中在线观看| 激情久久中文字幕| 欧美成ee人免费视频| 免费观看欧美在线视频的网站| 尹人成人综合网| 欧美国产一区视频在线观看| 久久久久欧美精品| 日韩午夜在线视频| 亚洲视频999| 国产曰批免费观看久久久| 久久久天天操| 欧美日本在线| 久久不见久久见免费视频1| 欧美一区二区三区免费看| 亚洲国产精品热久久| 99www免费人成精品| 国内精品免费午夜毛片| 亚洲第一黄色网| 国产欧美亚洲精品| 亚洲韩国青草视频| 国产精品尤物| 久热这里只精品99re8久| 欧美 日韩 国产在线| 欧美一区二区三区的| 欧美一区二区三区四区在线| 亚洲欧洲综合另类| 亚洲与欧洲av电影| 久久久久久久久久久一区| 亚洲美女在线看| 久久久噜噜噜久久人人看| 亚洲欧美日韩国产精品| 免费高清在线一区| 久久人人看视频| 国产亚洲欧洲997久久综合| 欧美激情亚洲自拍| 亚洲福利小视频| 鲁大师影院一区二区三区| 久久免费视频在线观看| 国产视频欧美| 久久精品人人做人人爽| 久久天天躁夜夜躁狠狠躁2022| 国产精品一区二区欧美| 午夜免费在线观看精品视频| 午夜日韩激情| 国产在线拍偷自揄拍精品| 欧美在线免费一级片| 欧美成人精品影院| 亚洲精品久久久久久久久久久久| 免费亚洲视频| 一本一道久久综合狠狠老精东影业 | 国产精品久久久久久五月尺| 一区二区三区欧美在线| 性18欧美另类| 亚洲国产精品美女| 国产精品视频观看| 免费观看一级特黄欧美大片| 一区二区三区高清视频在线观看| 久久精品国产免费看久久精品| 亚洲大片精品永久免费| 91久久精品一区| 欧美亚洲色图校园春色| 在线国产精品一区| 国产精品欧美一区二区三区奶水 | 亚洲综合二区| 亚洲欧洲一二三| 国产亚洲精品成人av久久ww| 奶水喷射视频一区| 亚洲一区欧美激情| 日韩视频免费观看高清完整版| 久久在线91| 浪潮色综合久久天堂| 久久精品夜色噜噜亚洲aⅴ| 亚洲一区二区在线| 这里是久久伊人| 亚洲视频在线观看网站| 99riav1国产精品视频| 日韩视频专区| 亚洲香蕉伊综合在人在线视看| 99国产精品国产精品毛片| 亚洲日本免费| 在线一区二区三区四区| 亚洲欧美区自拍先锋| 小黄鸭精品aⅴ导航网站入口| 先锋影院在线亚洲| 久久偷窥视频| 亚洲精品偷拍| 亚洲一级免费视频| 亚洲欧美亚洲| 欧美jjzz| 国产视频亚洲精品| 夜夜爽www精品| 久久久久久69| 9久re热视频在线精品| 欧美在线观看视频一区二区| 免费在线欧美视频| 国产午夜精品在线| 亚洲精品欧洲精品| 亚洲日本中文字幕| 亚洲欧洲精品一区| 美女日韩欧美| 一区二区三区高清| 男人的天堂亚洲| 国产精品成人观看视频免费 | 欧美片网站免费| 一区免费观看视频| 午夜精品久久久久久| 最近中文字幕mv在线一区二区三区四区| 一区二区三区精品久久久| 欧美成人亚洲| 99re66热这里只有精品4| 欧美国产日韩视频| 久久精品五月婷婷| 一区二区视频免费完整版观看| 亚洲欧美精品伊人久久| 亚洲最新视频在线| 国产精品国产三级国产普通话99| 一区二区三区黄色| 亚洲区一区二区三区| 欧美精品123区| 亚洲一区二区视频在线观看| 亚洲视频一区在线| 国产亚洲精品7777| 免费成人高清视频| 欧美激情第二页| 在线综合亚洲| 久久久免费精品| 亚洲一二三级电影| 亚洲女同性videos| 曰韩精品一区二区| 亚洲精品看片| 国产原创一区二区| 亚洲国产精品嫩草影院| 国产欧美一级| 亚洲第一二三四五区| 国产精品一区二区视频| 欧美成人一品| 国产伦精品一区二区三区四区免费 | 性久久久久久久久久久久| 午夜久久电影网| 日韩小视频在线观看专区| 亚洲欧美日韩成人| 亚洲伦理久久| 噜噜噜噜噜久久久久久91| 亚洲欧美视频| 欧美日韩精品免费观看视一区二区 | 国产亚洲成av人片在线观看桃 | 久久精品免费电影| 亚洲免费在线观看视频| 麻豆精品91| 欧美不卡视频一区| 在线看片第一页欧美| 久久国产精品久久久久久| 午夜视频一区在线观看| 欧美日韩免费在线| 亚洲欧洲精品一区| 一区二区三区免费网站|