#include#includeusingnamespacestd;constintINF=0x7fffff" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

hdu 3691 Nubulsa Expo

系統(tǒng) 2004 0

?

http://acm.hdu.edu.cn/showproblem.php?pid=3691

Stoer-Wagner算法 不理解不理解呀

大體步驟是這樣子的

1,用類似Prim 的過程求得最后更新點 和倒數第二更新點

2,求最后更新點和其它點的割集

3,將最后一個點合并到倒數第二個更新點上

代碼:

      #include<iostream>

#include<cstdio>

#include<cstring>



using namespace std;



const int INF=0x7fffffff;

const int N=305;

int a[N][N];

int dist[N];

bool visited[N],dele[N];

int n,m,st;

int nd1,nd2;

void Prim()

{

    memset(dist,0,sizeof(dist));

    for(int i=1;i<=n;++i)

    {

        if(!dele[i])

        {

            dist[i]=a[st][i];

        }

    }

    nd1=nd2=st;

    memset(visited,false,sizeof(visited));

    visited[st]=true;

    for(int w=1;w<n;++w)

    {

        int M=0,k=0;

        for(int i=1;i<=n;++i)

        {

            if(!dele[i]&&!visited[i]&&dist[i]>M)

            {

                M=dist[i];k=i;

            }

        }

        if(k==0)

        break;

        visited[k]=true;

        for(int i=1;i<=n;++i)

        {

            if(!dele[i]&&!visited[i])

            {

                dist[i]+=a[k][i];//這里好奇怪

            }

        }

        nd2=nd1;//最后更新點 和倒數第二更新點

        nd1=k;

    }

    return;

}

int Findmin()

{

    int sum=0;

    for(int i=1;i<=n;++i)

    {

        if(!dele[i])

        {

            sum+=a[nd1][i];//最后更新點的割集

        }

    }

    return sum;

}

void Removepoint()

{

    dele[nd1]=true;

    for(int i=1;i<=n;++i)

    {

        if(!dele[i]&&i!=nd2)

        {

            a[i][nd2]+=a[i][nd1];//合并最后更新點

            a[nd2][i]+=a[nd1][i];

        }

    }

}

int main()

{

    while(scanf("%d %d %d",&n,&m,&st)!=EOF)

    {

        if(!n&&!m&&!st)

        break;

        memset(a,0,sizeof(a));

        while(m--)

        {

            int i,j,k;

            scanf("%d %d %d",&i,&j,&k);

            a[i][j]+=k;//重邊

            a[j][i]+=k;

        }

        int ans=INF;

        memset(dele,false,sizeof(dele));//此點是否刪除

        for(int w=1;w<n;++w)

        {

            Prim();

            ans=min(ans,Findmin());

            Removepoint();

        }

        printf("%d\n",ans);

    }

    return 0;

}


    

?

?

?

hdu 3691 Nubulsa Expo


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 91热久久免费频精品99欧美 | 7777成年大片免费播放器 | 日本高清视频一区二区三区 | 九九热精品视频在线观看 | 奇米888888| 一级理论片免费观看在线 | 红色毛片 | 久久精品国产99国产 | 久久精品夜夜夜夜夜久久 | 四虎永久在线观看免费网站网址 | 久草久草久草 | 欧洲性大片xxxxx久久久 | 一区二区国产在线观看 | 国产成人做受免费视频 | 久久综合九色欧美综合狠狠 | 一级做a免费视频观看网站 一级做a爰片久久毛片唾 | 91亚洲精品一区二区在线观看 | 日韩在线观看一区二区三区 | 亚洲视频一区二区 | 狠狠视频| 日本久久网 | 天天综合在线观看 | 97福利视频在线观看 | 91系列在线 | 日韩毛片在线影视 | 欧美日韩免费在线 | 丹武至尊在线观看动漫 | 老子影院午夜伦手机不卡无 | 亚洲欧美在线精品一区二区 | 四小虎免费永久观看 | 日本一区二区三区四区 | 中文字幕伦视频 | 国产剧情一区二区三区 | chinese国产人妖视频网站 | 久久国产精品亚洲va麻豆 | 欧美日韩中文字幕久久伊人 | 免费女人18毛片a级毛片视频 | 色播性播爱播放影院 | 香蕉a视频 | 久久福利一区二区三区 | 国产成人精品午夜 |