栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

MST

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MST


prim

int prim(int x,int n)

{   

int sum=0;

memset(visit,false,sizeof(visit));

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

dis[i]=mp[x][i];

dis[x]=0;

visit[x]=true;

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

{

    int k,mincost=INF;

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

    if(!visit[j]&&dis[j]

    mincost=dis[k=j];

    if(mincost==INF) break;

    visit[k]=true;

    sum+=mincost;

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

    {

        if(!visit[j]&&dis[j]>mp[k][j])

        dis[j]=mp[k][j]; 

    }

}

return sum;

}

Kruskal

int F(int x){return fat[x]==x?x:F(fat[x]);}

void join(int x,int y)

{

int fx=F(x);

int fy=F(y);

if(fy!=fx)fat[fy]=fx;

}

void kruskal()

{

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

{

    if(k==n-1)break; 

    if(F(g[i].u)!=F(g[i].v))

    {

        join(g[i].u,g[i].v);

        sum+=g[i].di;k++;

    }

}

}

©著作权归作者所有:来自51CTO博客作者qinXpeng的原创作品,如需转载,请注明出处,否则将追究法律责任


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/232541.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号